安辉就是我 2017-03-03 10:59 采纳率: 0%
浏览 1418
已采纳

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出现异常了......");
}

}

  • 写回答

3条回答 默认 最新

  • 夕阳雨晴 2017-03-03 11:03
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • 关注

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

    评论
  • 安辉就是我 博客专家认证 2017-03-05 09:40
    关注

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

    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 电脑锁屏时vba运行SAP,excel数据不能复制到SAP
  • ¥50 74LS系列 74LS00 74LS04设计一个RS485电路(关键词-差分)
  • ¥30 各位help写一下代码
  • ¥15 在运行SDEdit模型下载不了
  • ¥15 求51控制l298n驱动的小车中超声波避障怎么写
  • ¥15 电脑连上WIFI却用不了
  • ¥30 MATLAB在RLC电路的固有响应和阶跃响应GUI仿真报告
  • ¥15 hyper-v出现的问题
  • ¥15 有能用的可加酬金,求可以批量下载懒人听书的软件,能登录自己帐号的。
  • ¥100 高博一起做RGB-D SLAM(5)VO无法出visualisation问题