java-Annotation 反射

本文介绍如何使用Java注解结合AOP实现方法级别的日志记录功能。通过@Aspect注解定义切面,并利用@Around注解进行环绕通知,实现了在目标方法执行前后打印日志的功能。此外还提供了具体的测试代码。
摘要由CSDN通过智能技术生成
java中的注解也可以反射

切面注解:

@Aspect
public class LogAspect {

@Around(value = "@annotation(com.gym.Monitor)",argNames = "ssss")
public Object log(ProceedingJoinPoint pjp) throws Throwable{
System.out.println("BEGIN-------------------" +pjp+"-------------------");
Object obj = pjp.proceed();
System.out.println("END-------------------" +pjp+"-------------------"+obj);
return obj;
}
}



测试:

@Test
public void testAspectJAnnotation() throws Exception{
LogAspect la = new LogAspect();
Method method = la.getClass().getMethod("log", ProceedingJoinPoint.class);

Annotation annotation = method.getAnnotation(Around.class);

String s = resolveExpression(annotation);
System.out.println(s);
Object obj = annotation.getClass().getMethod("argNames").invoke(annotation);
System.out.println(obj);
}



private String resolveExpression(Annotation annotation) throws Exception {
String[] EXPRESSION_PROPERTIES = new String[] {"value", "pointcut"};
String expression = null;
for (String methodName : EXPRESSION_PROPERTIES) {
Method method;
try {
method = annotation.getClass().getDeclaredMethod(methodName);
}
catch (NoSuchMethodException ex) {
method = null;
}
if (method != null) {
String candidate = (String) method.invoke(annotation);
if (StringUtils.hasText(candidate)) {
expression = candidate;
}
}
}
return expression;
}


输出:
@annotation(com.gym.Monitor)
ssss
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值