现在需求是后台需要判断客户端是否登录,客户端请求参数校验。
我现在的想法是用aop拦截所有的请求,然后通过aop处理完成之后
再决定是否接给Controller处理。
例如修改用户的Contrller,有一个CommonParameter参数,有客户端的token。我需要在拦截器里面先判断这个token是不是正确的,然后不正确就直接返回客户端json了,如果准确的就给这个Controller处理。
@RequestMapping(value="/edit_user",method = RequestMethod.POST)
@ResponseBody
public ModelMap editUser(@ModelAttribute("common") CommonParameter common, @ModelAttribute("user") User user){
ModelMap modelMap=userService.editUser(common,user);
return modelMap;
}
这是我照着网上写的拦截器UserTokenInterceptor,方法有执行,但是我不知道如何拦截。
@Aspect
@Component
public class UserTokenInterceptor {
//controller包的子包里面任何方法
@Pointcut("execution(public * com.ansen.birthday.assistant.controller.*.*(..))")
public void checkToken(){
}
@Before("checkToken()")
public void beforeCheckToken() {
System.out.println("调用方法之前。。。。");
}
@AfterReturning("checkToken()")
public void afterCheckToken(ProceedingJoinPoint joint) {
System.out.println("调用方法结束之后。。。。");
}
//抛出异常时才调用
@AfterThrowing("checkToken()")
public void afterThrowing() {
System.out.println("校验token出现异常了......");
}
}