Spring aop拦截Conreoller

现在需求是后台需要判断客户端是否登录,客户端请求参数校验。

我现在的想法是用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出现异常了......");
}

}

推荐这篇文章。你试着把参数打印出来,就知道该怎么拦截了。http://blog.csdn.net/wangpeng047/article/details/8560694

aop不适合你的这个需求,应该使用interceptor进行请求过滤,满足条件才放行

我现在通过aop实现了。。。。。但是感觉代码有点别扭 谢谢大家的回答了