利用annotation和aspect处理耗时计算和参数打印
2021-01-22 01:12
标签:aspect not java nat except classname ram 并且 npoi 利用annotation和aspect处理耗时计算和参数打印 标签:aspect not java nat except classname ram 并且 npoi 原文地址:https://www.cnblogs.com/Ivan10000/p/13289586.html@Component
@Aspect
public class MyAspect {
// /**
// * 切点表达式:
// * ..两个点表明多个,*代表一个
// * 表达式代表切入com..service包下的所有类的所有方法,方法参数不限,返回类型不限。
// * 其中访问修饰符可以不写,不能用*,,第一个*代表返回类型不限,第二个*表示所有类,第三个*表示所有方法,..两个点表示方法里的参数不限。
// */
// private final String POINT_CUT = "execution(* com..controller.*.*(..))";
//
// /**
// * 命名切点
// * public 切点可访问性修饰符
// * 与类可访问性修饰符的功能是相同的,它可以决定定义的切点可以在哪些类中可使用。
// * pointCut 切点名称
// * void 返回类型
// *
// * 因为命名切点仅利用方法名及访问修饰符的信息,
// * 一般定义方法的返回类型为 void ,并且方法体为空
// */
// @Pointcut(POINT_CUT)
// public void pointCut(){}
//
// /**
// * 在切点方法之前执行
// * @param joinPoint
// */
// @Before(value="pointCut()")
// public void doBefore(JoinPoint joinPoint){
// System.out.println("@Before:切点方法之前执行.....");
// }
//
// /**
// * 在切点方法之后执行
// * @param joinPoint
// */
// @After(value="pointCut()")
// public void doAfter(JoinPoint joinPoint){
// System.out.println("@After:切点方法之后执行.....");
// }
//
// /**
// * 切点方法返回后执行
// * 如果第一个参数为JoinPoint,则第二个参数为返回值的信息
// * 如果第一个参数不为JoinPoint,则第一个参数为returning中对应的参数
// * returning:限定了只有目标方法返回值与通知方法参数类型匹配时才能执行后置返回通知,否则不执行,
// * 参数为Object类型将匹配任何目标返回值
// */
// @AfterReturning(value = "pointCut()",returning = "result")
// public void doAfter(JoinPoint joinPoint, Object result){
// System.out.println("@AfterReturning:切点方法返回后执行.....");
// System.out.println("返回值:"+result);
// }
//
// /**
// * 切点方法抛异常执行
// * 定义一个名字,该名字用于匹配通知实现方法的一个参数名,当目标方法抛出异常返回后,将把目标方法抛出的异常传给通知方法;
// * throwing:限定了只有目标方法抛出的异常与通知方法相应参数异常类型时才能执行后置异常通知,否则不执行,
// * 对于throwing对应的通知方法参数为Throwable类型将匹配任何异常。
// * @param joinPoint
// * @param exception
// */
// @AfterThrowing(value = "pointCut()",throwing = "exception")
// public void doAfterThrowing(JoinPoint joinPoint,Throwable exception){
// System.out.println("@afterThrowing:切点方法抛异常执行.....");
// }
//
// /**
// *
// * 属于环绕增强,能控制切点执行前,执行后,,用这个注解后,程序抛异常,会影响@AfterThrowing这个注解
// *
// * org.aspectj.lang.JoinPoint 接口表示目标类连接点对象,它定义这些主要方法。
// * Object[] getArgs():获取连接点方法运行时的入参列表。
// * Signature getSignature():获取连接点的方法签名对象。
// * Object getTarget():获取连接点所在的目标对象。
// * Object getThis():获取代理对象。
// * @param pjp
// * @return
// * @throws Throwable
// */
// @Around(value="pointCut()")
// public Object doAround(ProceedingJoinPoint pjp) throws Throwable{
// System.out.println("@Around:切点方法环绕start.....");
// Object[] args = pjp.getArgs();
// Object o = pjp.proceed(args);
// System.out.println("@Around:切点方法环绕end.....");
// return o;
// }
@Before("@annotation(pp)")
public void doBefore(JoinPoint pjp, PrintParameters pp){
String methodName = pjp.getSignature().getName();
String className = pjp.getSignature().getDeclaringTypeName();
System.out.println(String.format("[class=%s, method=%s, args=%s] Input params.", className, methodName, Arrays.toString(pjp.getArgs())));
}
@AfterReturning(value = "@annotation(pp)",returning = "result")
public void doAfter(JoinPoint pjp, Object result, PrintParameters pp){
String methodName = pjp.getSignature().getName();
String className = pjp.getSignature().getDeclaringTypeName();
System.out.println(String.format("[class=%s, method=%s, return=%s] Return param.", className, methodName, result));
}
@Around("@annotation(ct)")
public Object doAround(ProceedingJoinPoint pjp, ComputingTime ct) throws Throwable {
long begin = System.currentTimeMillis();
String methodName = pjp.getSignature().getName();
String className = pjp.getSignature().getDeclaringTypeName();
System.out.println(String.format("[class=%s, method=%s] Elapsed time begin.", className, methodName));
Object[] args = pjp.getArgs();
Object obj = pjp.proceed(args);
System.out.println(String.format("[class=%s, method=%s, time=%dms] Elapsed time end.", className, methodName, System.currentTimeMillis() - begin));
return obj;
}
}
文章标题:利用annotation和aspect处理耗时计算和参数打印
文章链接:http://soscw.com/index.php/essay/45215.html