不同通知类型获得参数、返回值、返回异常
不同通知类型获得参数、返回值、返回异常:

参数:
前置后置,异常后,成功运行后:方法中参数写
JoinPoint joinPoint,使用joinPoint调用方法,getArgs()方法返回的是测试类那边传进来的参数,被这个方法打包成数组类型放入Object类型的数组中,然后用打印Arrays.toString(args)就可以知道传进来的参数是啥
@Before("pt()")
public void before(JoinPoint joinPoint) throws Throwable{
Object[] args=joinPoint.getArgs();
System.out.println(Arrays.toString(args));
}
环绕型就有所不同:方法中的参数用
ProceedingJoinPoint joinPoint,其余都一样样;对了ProceedingJoinPoint还包含一个方法,其方法的参数就是args,所以这里就可以直接把args数组传进去,然后joinPoint.proceed(args)调用执行当前的实体类方法
@Around("pt()")
public Object arounddd(ProceedingJoinPoint joinPoint) throws Throwable {
Object[] args=joinPoint.getArgs();
Object proceed=joinPoint.proceed(args);
return proceed;
}
但是这个参数可以进行修改,将得到的参数改一下,如令args[0]等于一个别的值,参数就变了,再次执行
joinPoint.proceed(args)时,其中的参数就变成了别的,于是最后结果,返回的也是别的参数相对应的结果
@Around("pt()")
public Object arounddd(ProceedingJoinPoint joinPoint) throws Throwable {
Object[] args=joinPoint.getArgs();
args[0]=6;
Object proceed=joinPoint.proceed(args);
return proceed;
}
返回值:
- @AfterReturning成功运行后:注解@AfterReturning(value = “pt()”,returning = “args”),其中表示返回值,再方法中参数也写
args,与注解中的参数保持一致即可,最终打印的args就是实体类返回的值,(与环绕方法不同的是他不用在方法中加载进实体类的方法,直接利用注解中的returning参数就可以打印出实体类的返回值,当然也得实体类不是void返回型才可以)
@AfterReturning(value = "pt()",returning = "args")
public void show(Object args){
System.out.println(args);
}
返回异常:
@AfterThrowing:和上面的成功后返回返回值的用法一样
其他的通知类型就直接在方法内使用try{} catch(){}打印就行
@AfterThrowing(value = "pt()",throwing = "args")
public void pp(Throwable args){
System.out.println(args);
}