写在前面
项目使用SpringMVC+MyBatis开发,Spring版本为:4.1.9.RELEASE。此项目为历史项目,现有需求为,增加记录系统管理员操作日志,现有实现的方式有很多种,比如AOP等等,本文使用拦截器+自定义注解实现。
拦截器介绍
Spring 的 Interceptor (拦截器)是通过 HandlerInterceptor 接口实现的。
4.1.9.RELEASE版本HandlerInterceptor文档地址https://docs.spring.io/spring-framework/docs/4.1.9.RELEASE/javadoc-api/org/springframework/web/servlet/HandlerInterceptor.html最新版本HandlerInterceptor文档地址
https://docs.spring.io/spring-framework/docs/current/javadoc-api/org/springframework/web/servlet/HandlerInterceptor.htmlSpring 的 handle mapping(处理器映射)机制包含handler interceptors(处理拦截器),当你需要需要对某一请求应用特定的功能时,拦截器会变得很有用。
自定义处理映射拦截器必须实现 org.springframework.web.servlet.HandlerInterceptor 接口。这个定义了三个方法:
/**
* 整个请求处理完毕回调方法,即在视图渲染完毕时回调,如性能监控中我们可以在此记录结束时间并输出消耗时间,还可以进行一些资源清理,类似于try-catch-finally中的finally,但仅调用处理器执行链中
*/
@Override
public void afterCompletion(HttpServletRequest req, HttpServletResponse res, Object obj, Exception ex)
throws Exception {
}
/**
* 后处理回调方法,实现处理器的后处理(但在渲染视图之前),此时我们可以通过modelAndView(模型和视图对象)对模型数据进行处理或对视图进行处理,modelAndView也可能为null。
*/
@Override
public void postHandle(HttpServletRequest req, HttpServletResponse res, Object obj, ModelAndView mav)
throws Exception {
}
/**
* 预处理回调方法,实现处理器的预处理(如检查登陆),第三个参数为响应的处理器,自定义Controller
* 返回值:true表示继续流程(如调用下一个拦截器或处理器);false表示流程中断(如登录检查失败),不会继续调用其他的拦截器或处理器,此时我们需要通过response来产生响应;
*/
@Override
public boolean preHandle(HttpServletRequest req, HttpServletResponse res, Object handler) throws Exception {
}
根据本次需求,在自定义拦截器中preHandle(...)方法中处理即可。
如果项目中存在多个拦截器,那么Spring会根据配置的顺序