Java使用注解和动态代理实现方法调用时的日志记录示例

本文展示了如何在Java中使用注解和动态代理来实现方法调用时的日志记录。首先定义了一个名为`LogTag`的注解,接着创建了一个接口`ITest`,然后通过代理类`ProxyBean`实现了对方法调用的拦截,检查方法上的`LogTag`注解并打印相应日志。最后,创建了一个测试类`TestBean`,在`excuteBusiness`方法上使用了`@LogTag(level = "warn")`注解,验证了动态代理和日志记录的逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.定义一个注解:

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface LogTag {
    String level() default "info";
}

2.定义一个接口

public interface ITest {
    void excuteBusiness();
}

3.定义一个代理类

/**
* 代理类
* @author chenshuai
* @version 1.0
*
*/
public class ProxyBean implements InvocationHandler {
    private Object o;
    /**
     * @return the o
     */
    private Object getO() {
        return o;
    }
    /**
     * @param o the o to set
     */
    private void setO(Object o) {
        this.o = o;
    }
    /**
     * 创建代理
     * @param obj
     * @return
     */
    public static <T> T createProxy(T obj) {
        ProxyBean tem = new ProxyBean();
        tem.setO(obj);
        return (T) Proxy.newProxyInstance(obj.getClass().getClassLoader(), obj.getClass().getInterfaces(), tem);
    }
    /*
     * (non-Javadoc)
     *
     * @see java.lang.reflect.InvocationHandler#invoke(java.lang.Object,
     * java.lang.reflect.Method, java.lang.Object[])
     */
    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        //从实际的类对象中查找到所调用的具体方法,用来检测实际类的方法上的注解
        //否则需要把注解加载接口的方法上
        Method[] methods = o.getClass().getMethods();
        List<Class<?>> types = new ArrayList<Class<?>>();
        Method mm = null;
        //通过反射查找方法
        if (args == null || args.length == 0) {
            mm = o.getClass().getMethod(method.getName(), null);
        } else {
            for (Object oo : args) {
                types.add(oo.getClass());
            }
            mm = o.getClass().getMethod(method.getName(), (Class<?>[]) types.toArray());
        }
        System.out.println("代理启动");
        //检查注解类型
        Annotation[] annos = mm.getAnnotations();
        for (Annotation anno : annos) {
            if (anno instanceof LogTag) {
                LogTag tem = (LogTag) anno;
                System.out.println("探测到了LogTag注解,并且发现注解的level值为:" + tem.level());
            }
        }
        //调用具体的方法,执行业务逻辑
        method.invoke(o, args);
        System.out.println("代理结束");
        return null;
    }
}

4.定义一个入口测试类

public class TestBean implements ITest {
   
    @LogTag(level = "warn")
    public void excuteBusiness() {
        System.out.println("启动业务处理");
    }
    public static void main(String[] args) {
        ITest a = new TestBean();
        ITest proxy = ProxyBean.createProxy(a);
        proxy.excuteBusiness();
    }
}

运行结果


知识点:
1.Java动态代理:需要注意的是Java的动态代理要求被代理类必须继承自接口。
2.注解:注意@Retention和@Target两个注解的使用方法。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值