使用拦截器(HandlerInterceptor)+自定义注解记录系统操作日志

写在前面

项目使用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会根据配置的顺序࿰

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值