同时拦截多个方法,拦截器中取被拦截方法的信息,比如方法名、参数等。
由于在一个项目中拦截器的使用必不可少,我在此整理一下用法:
1、before :在方法执行前拦截
//updateUser前拦截
@Before("execution(* com.ll.test.manager.UserManager.updateUser(..)) && args(token, user,..)")
public void beforeUpdateUser(String token, UserEntity user) throws Throwable{
//可以在这里执行相应的操作 比如更改参数
System.out.println("beforeUpdateUser ====user == "+ JSON.toJSONString(user));
}
2、After:在方法执行后拦截
//updateUser后拦截
@After("execution(* com.ll.test.manager.UserManager.updateUser(..)) && args(token, user,..)")
public void afterUpdateUser(String token, UserEntity user) throws Throwable{
System.out.println("afterUpdateUser ====user == "+ JSON.toJSONString(user));
//可以在这里执行相应的操作 比如更新session等
}
3、Around:可以在方法执行前做相应的操作也可以在方法执行后做相应的操作,这个尤其重要,因为当拦截多个方法时,需要取当前拦截的方法的信息时只有Around可以实现。示例:
//拦截多个方法 并且取得拦截的具体某个方法的信息
@Around("execution(* com.ll.test.manager.Analysis*.search*(..)) or execution(* com.ll.test.manager.Body*.search*(..)) or execution(* com.ll.test.manager.Data*.search*(..)) or execution(* com.ll.test.manager.Find*.search*(..))")
public Object aroundSearchInformation(ProceedingJoinPoint proceedingJoinPoint) throws Throwable{
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date start = new Date();
Signature sig = proceedingJoinPoint.getSignature();
MethodSignature msig = null;
if (!(sig instanceof MethodSignature)) {
throw new IllegalArgumentException("该注解只能用于方法");
}
msig = (MethodSignature) sig;
Object target = proceedingJoinPoint.getTarget();
Method currentMethod = target.getClass().getMethod(msig.getName(), msig.getParameterTypes());
System.out.println("////////////"+currentMethod.getName()+"///////start/////// "+sdf.format(start));
//放行 这里执行被拦截的方法
Object result = proceedingJoinPoint.proceed();
Date end = new Date();
System.out.println("////////////"+currentMethod.getName()+"////////end////// "+sdf.format(end));
return result;
}