在spring 3.0甚础上,起来越多的用到了注解,从前的拦截器在配置文件中需要这样配置

  1. <beans...>
  2. ...
  3. <bean id="measurementInterceptor"
  4. class="com.apress.springrecipes.court.web.MeasurementInterceptor"/>
  5. <bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
  6. <property name="interceptors">
  7. <list>
  8. <ref bean="measurementInterceptor"/>
  9. </list>
  10. </property>
  11. ...
  12. </bean>
  13. <bean class="org.springframework.web.servlet.mvc.support
  14. .ControllerClassNameHandlerMapping">
  15. <property name="interceptors">
  16. <list>
  17. <ref bean="measurementInterceptor"/>
  18. </list>
  19. </property>
  20. </bean>
  21. ....
  22. </beans>

现在用注解只需要这样:

  1. <mvc:interceptors>
  2. <mvc:interceptor>
  3. <mvc:mapping path="/*/*.shtml"/>//映射路径后缀名
  4. <bean class="x.x.x.filter.SessionFilter"/>//自定义拦截器
  5. </mvc:interceptor>
  6. </mvc:interceptors>

SessionFilter.java代码:

  1. public class SessionFilter implements HandlerInterceptor {
  2. @Override
  3. public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object o) throws Exception {
  4. //  后台session控制
  5. Object user=request.getSession().getAttribute("username");
  6. String returnUrl = request.getRequestURI();
  7. if(null==user){
  8. if(returnUrl.equals("/public/getImg.shtml")||returnUrl.equals("/public/checkLogin.shtml")||returnUrl.equals("/public/login.shtml")||returnUrl.equals("/public/logOut.shtml")){
  9. return true;
  10. }else{
  11. response.setContentType("text/html");
  12. response.setCharacterEncoding("utf-8");
  13. PrintWriter out = response.getWriter();
  14. StringBuilder builder = new StringBuilder();
  15. builder.append("<script type=\"text/javascript\" charset=\"UTF-8\">");
  16. builder.append("alert(\"请重新登陆!\");");
  17. builder.append("window.location.href=\"/public/login.shtml\";");
  18. builder.append("</script>");
  19. out.print(builder.toString());
  20. out.close();
  21. return false;
  22. }
  23. }
  24. return true;
  25. }
  26. @Override
  27. public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse response, Object o, ModelAndView modelAndView) throws Exception {
  28. }
  29. @Override
  30. public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse response, Object o, Exception e) throws Exception {
  31. }
  32. /**
  33. * @param request
  34. * @return Create Date:2013-6-5
  35. * @author Shine
  36. * Description:获取IP
  37. */
  38. private String getIpAddr(HttpServletRequest request) {
  39. String ip = request.getHeader("x-forwarded-for");
  40. if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
  41. ip = request.getHeader("Proxy-Client-IP");
  42. }
  43. if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
  44. ip = request.getHeader("WL-Proxy-Client-IP");
  45. }
  46. if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
  47. ip = request.getRemoteAddr();
  48. }
  49. return ip;
  50. }
  51. }

这个拦截器的目的就是:用户所属的session不存在后进行对控制器请求的拦截,使跳转到首页。对于HandlerInterceptor这个类这里不多说,网上有的可能说的更好,这里只简单说下它的三个方法,preHandle、postHandle和afterCompletion。

(1 )preHandle(WebRequest request) 方法。该方法将在请求处理之前进行调用,也就是说会在Controller 方法调用之前被调用。这个方法跟HandlerInterceptor 中的preHandle 是不同的,主要区别在于该方法的返回值是void ,也就是没有返回值,所以我们一般主要用它来进行资源的准备工作,比如我们在使用Hibernate 的时候可以在这个方法中准备一个Hibernate 的Session 对象,然后利用WebRequest 的setAttribute(name, value, scope)把它放到WebRequest 的属性中。这里可以说说这个setAttribute 方法的第三个参数scope ,该参数是一个Integer类型的。在WebRequest 的父层接口RequestAttributes 中对它定义了三个常量:

SCOPE_REQUEST :它的值是0 ,代表只有在request 中可以访问。

SCOPE_SESSION :它的值是1 ,如果环境允许的话它代表的是一个局部的隔离的session,否则就代表普通的session,并且在该session范围内可以访问。

SCOPE_GLOBAL_SESSION :它的值是2 ,如果环境允许的话,它代表的是一个全局共享的session,否则就代表普通的session,并且在该session 范围内可以访问。

(2 )postHandle(WebRequest request, ModelMap model) 方法。该方法将在请求处理之后,也就是在Controller 方法调用之后被调用,但是会在视图返回被渲染之前被调用,所以可以在这个方法里面通过改变数据模型ModelMap 来改变数据的展示。该方法有两个参数,WebRequest 对象是用于传递整个请求数据的,比如在preHandle 中准备的数据都可以通过WebRequest 来传递和访问;ModelMap 就是Controller 处理之后返回的Model 对象,我们可以通过改变它的属性来改变返回的Model 模型。

(3 )afterCompletion(WebRequest request, Exception ex) 方法。该方法会在整个请求处理完成,也就是在视图返回并被渲染之后执行。所以在该方法中可以进行资源的释放操作。而WebRequest 参数就可以把我们在preHandle 中准备的资源传递到这里进行释放。Exception 参数表示的是当前请求的异常对象,如果在Controller中抛出的异常已经被Spring 的异常处理器给处理了的话,那么这个异常对象就是是null 。

参考:http://haohaoxuexi.iteye.com/blog/1750680

springMVC 拦截器简单配置的更多相关文章

  1. springMVC拦截器简单配置

    <!-- 拦截器 -->    <mvc:interceptors>        <mvc:interceptor>            <!-- 拦截所 ...

  2. springmvc拦截器的配置、使用

    springmvc拦截器的配置.使用:1.自定义拦截器,实现HandlerInterceptor接口. package com.bybo.aca.web.interceptor; import jav ...

  3. SpringMVC拦截器简单使用

    一.拦截器的配置 1.传统的配置 Xml代码   <bean class="org.springframework.web.servlet.mvc.annotation.Default ...

  4. SpringMVC拦截器的配置与使用详解

         一.SpringMVC拦截器简介      Spring MVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理.在springmvc中,定义拦截 ...

  5. 【Spring】14、SpringMVC拦截器的配置

    拦截器: com.zk.interceptors.MyInterceptor 实现了 HandlerInterceptor接口,可以拦截@RequestMapping注解的类和方法 第一种方式 < ...

  6. [转]SpringMVC拦截器简单教程

    亲测有用,地址: http://blog.csdn.net/tjcyjd/article/details/7498236

  7. springmvc拦截器的简单了解

    1.定义一个拦截器 2.在springmvc.xml中配置拦截器. (1)拦截器拦截的请求是建立在前端控制器配置之下的,若DispatcherServlet拦截的是*.action,则拦截器即使配置 ...

  8. spring boot配置springMVC拦截器

    spring boot通过配置springMVC拦截器 配置拦截器比较简单, spring boot配置拦截器, 重写preHandle方法. 1.配置拦截器: 2重写方法 这样就实现了拦截器. 其中 ...

  9. Springboot中SpringMvc拦截器配置与应用(实战)

    一.什么是拦截器,及其作用 拦截器(Interceptor): 用于在某个方法被访问之前进行拦截,然后在方法执行之前或之后加入某些操作,其实就是AOP的一种实现策略.它通过动态拦截Action调用的对 ...

随机推荐

  1. win7 用户目录

    robocopy "C:\Users" "D:\Users" /E /COPYALL /XJ /XD "C:\Users\Administrator& ...

  2. aws在线技术峰会笔记-主会场

    容器服务:Elastic container service IoT可以采用无服务器架构.

  3. Java vs. C#

    Java Program Structure C# package hello; public class HelloWorld {    public static void main(String ...

  4. AlarmManager 实现闹钟的基本功能

    先上效果图 这是一个利用AlarmManager做的最简单的闹钟!迟点再把重复响铃(例如星期一,星期三,重复响铃) 1.MainActivity package com.example.domeref ...

  5. 如何理解 Java 中的 <T extends Comparable<? super T>>

    Java 中类似 <T extends Comparable<? super T>> 这样的类型参数 (Type Parameter) 在 JDK 中或工具类方法中经常能看到. ...

  6. mysql exists 和 in的效率比较

    这条语句适用于a表比b表大的情况 select * from ecs_goods a where cat_id in(select cat_id from ecs_category b); 这条语句适 ...

  7. static代码块与{}代码块的比较

    第一个例子: public class StaticDemo { { System.out.println("{} 代码块"); } static{ System.out.prin ...

  8. 【ros】rplidar Hector Slam

    想用rplidar跑一下hector slam,在网上发现了几个教程写的都不错,但是亲测发现都有点不足,综合了一下,进行补充. 1. 安装ros 和 创建工作空间 http://blog.csdn.n ...

  9. CMD规范(通用模块定义规范)(翻译)

    最近在使用sea.js.大家知道sea.js遵循CMD规范.该规范的英文说明很简洁,我试着翻译了一下,旨在交流. Common Module Definition 通用模块定义规范 This spec ...

  10. mysql 中关于周和月份的表示

    本周:YEARWEEK(date_format(create_time,'%Y-%m-%d')) = YEARWEEK(now()) 上周:YEARWEEK(date_format(create_ti ...