Spring MVC 中 HandlerInterceptorAdapter的使用

一般情况下,对来自浏览器的请求的拦截,是利用Filter实现的,这种方式可以实现Bean预处理、后处理。 
Spring MVC的拦截器不仅可实现Filter的所有功能,还可以更精确的控制拦截精度。 

Spring为我们提供了org.springframework.web.servlet.handler.HandlerInterceptorAdapter这个适配器,继承此类,可以非常方便的实现自己的拦截器。他有三个方法:

 

[java]  view plain copy
 
  1. public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)    
  2.         throws Exception {    
  3.         return true;    
  4.     }    
  5.     public void postHandle(    
  6.             HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView)    
  7.             throws Exception {    
  8.     }    
  9.     public void afterCompletion(    
  10.             HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)    
  11.             throws Exception {    
  12.     }    


分别实现预处理、后处理(调用了Service并返回ModelAndView,但未进行页面渲染)、返回处理(已经渲染了页面) 
在preHandle中,可以进行编码、安全控制等处理; 
在postHandle中,有机会修改ModelAndView; 
在afterCompletion中,可以根据ex是否为null判断是否发生了异常,进行日志记录。 

如果基于xml配置使用Spring MVC,
可以利用SimpleUrlHandlerMapping、BeanNameUrlHandlerMapping进行Url映射(相当于struts的path映射)和拦截请求(注入interceptors),
如果基于注解使用Spring MVC,可以使用DefaultAnnotationHandlerMapping注入interceptors。
注意无论基于xml还是基于注解,HandlerMapping bean都是需要在xml中配置的。 

一个demo: 

public class LogAuditInterceptor extends HandlerInterceptorAdapter{

	private Log logger = LogFactory.getLog(this.getClass());
	
	@Autowired
	private LogAuditService logAuditService;
	
	@Override
	public void afterCompletion(HttpServletRequest request, 
			HttpServletResponse response, Object handler, Exception ex)
			throws Exception {
		logger.debug("LogAuditInterceptor.afterCompletion run...");
		String excMsg = (String) request.getAttribute("exception_msg");
		String userId = request.getParameter("userId");
		LogAudit logAudit = new LogAudit();
		if(StringUtils.isNotEmpty(userId)){
			Pattern pattern = Pattern.compile("[0-9]*");
			Matcher isNum = pattern.matcher(userId);
			if(!isNum.matches()){
				logAudit.setUserId((long)0);
			}else{
				logAudit.setUserId(Long.valueOf(userId));
			}
		}else{
			logAudit.setUserId((long)0);
		}
		logAudit.setIp(RequestUtil.getRealIp(request));
		logAudit.setAction(request.getRequestURI());
		logAudit.setMethod(request.getMethod());
		logAudit.setLogAdminFlag(LogAdminFlag.NO.toStringValue());
		logAudit.setSuccessFlag(SuccessFlag.YES.toStringValue());
		logAudit.setCreatedTime(new Date());
		if(StringUtils.isNotEmpty(excMsg)){
			logAudit.setSuccessFlag(SuccessFlag.NO.toStringValue());
			logAudit.setErrorMessage(excMsg);
		}
		logAuditService.addLogAudit(logAudit);
	}
}

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值