一般情况下,对来自浏览器的请求的拦截,是利用Filter实现的,这种方式可以实现Bean预处理、后处理。
Spring MVC的拦截器不仅可实现Filter的所有功能,还可以更精确的控制拦截精度。
Spring为我们提供了org.springframework.web.servlet.handler.HandlerInterceptorAdapter这个适配器,继承此类,可以非常方便的实现自己的拦截器。他有三个方法:
- public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
- throws Exception {
- return true;
- }
- public void postHandle(
- HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView)
- throws Exception {
- }
- public void afterCompletion(
- HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
- throws Exception {
- }
分别实现预处理、后处理(调用了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); } }
相关推荐
Spring MVC的HandlerInterceptorAdapter拦截器适配器拦截请求
6.8.1. 在Spring中使用AspectJ来为domain object进行依赖注入 6.8.1.1. @Configurable object的单元测试 6.8.1.2. 多application context情况下的处理 6.8.2. Spring中其他的AspectJ切面 6.8.3. 使用Spring IoC来...
1. springmvc 中的拦截器是由实现 HandlerInterceptor 或者继承 HandlerInterceptorAdapter 来实现的。 2. 自定义实现一个拦截器的步骤: a). 定义一个实现 HandlerInterceptor 接口 的类
6.8.1. 在Spring中使用AspectJ进行domain object的依赖注入 6.8.2. Spring中其他的AspectJ切面 6.8.3. 使用Spring IoC来配置AspectJ的切面 6.8.4. 在Spring应用中使用AspectJ加载时织入(LTW) 6.9. 更多资源 7...
6.8.1. 在Spring中使用AspectJ来为domain object进行依赖注入 6.8.2. Spring中其他的AspectJ切面 6.8.3. 使用Spring IoC来配置AspectJ的切面 6.8.4. 在Spring应用中使用AspectJ Load-time weaving(LTW) 6.9. ...
15.1.1 拦截器的定义 要使用Spring MVC中的拦截器,就需要对拦截器类进行定义和配置。通常拦截器类可以通过两种方式来定义。 通过实现HandlerInterceptor接口,或继承HandlerInterceptor接口的实现类(如...
6.8.1. 在Spring中使用AspectJ进行domain object的依赖注入 6.8.2. Spring中其他的AspectJ切面 6.8.3. 使用Spring IoC来配置AspectJ的切面 6.8.4. 在Spring应用中使用AspectJ加载时织入(LTW) 6.9. 更多资源 7...
6.8.4. 在Spring应用中使用AspectJ Load-time weaving(LTW) 6.9. 其它资源 7. Spring AOP APIs 7.1. 简介 7.2. Spring中的切入点API 7.2.1. 概念 7.2.2. 切入点实施 7.2.3. AspectJ切入点表达式 7.2.4. ...
前段时间学习了下SpringMVC和MyBatis,于是练了...权限操作拦截通过实现HandlerInterceptorAdapter接口实现,充分利用SpringMVC,集成了POI,实现导出Excel功能。数据库采用MySql,文件在src\resources\systest.sql中。
我们可以在Spring中创建自己的拦截器,方法是实现org.springframework.web.servlet.HandlerInterceptor接口或重写抽象类org.springframework.web.servlet.handler.HandlerInterceptorAdapter,后者提供的基本实现这...
1.基于mvc实现基本的数据增删改查操作。 2.已经分别集成log4j和logback日志插件。 3.已经集成Druid连接池监控。 4.已经集成的Redis缓存,基于jedis使用缓存,实现客户端分片。 5.添加CommonInterceptor类实现...