服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - 一篇学会Spring MVC 拦截器的骚操作

一篇学会Spring MVC 拦截器的骚操作

2021-11-03 22:47程序员千羽 Java教程

“Spring MVC中的拦截器(Interceptor)类似于Servlet中的过滤器(Filter),它主要用于拦截用户请求并作相应的处理。例如通过拦截器可以进行权限验证、记录请求信息的日志、判断用户是否登录等。

一篇学会Spring MVC 拦截器的骚操作

GitHub:https://github.com/nateshao/ssm/tree/master/110-springmvc-intercepter

什么是拦截器?

Spring MVC中的拦截器(Interceptor)类似于Servlet中的过滤器(Filter),它主要用于拦截用户请求并作相应的处理。例如通过拦截器可以进行权限验证、记录请求信息的日志、判断用户是否登录等。

要使用Spring MVC中的拦截器,就需要对拦截器类进行定义和配置。通常拦截器类可以通过两种方式来定义。

  • 第一种:通过实现HandlerInterceptor接口,或继承HandlerInterceptor接口的实现类(如HandlerInterceptorAdapter)来定义。
  • 第二种:通过实现WebRequestInterceptor接口,或继承WebRequestInterceptor接口的实现类来定义。

以实现HandlerInterceptor接口方式为例,自定义拦截器类的代码如下:

  1. public class CustomInterceptor implements HandlerInterceptor { 
  2.     /** 
  3.      * 该方法会在控制器方法前执行,其返回值表示是否中断后续操作。 
  4.      * 当其返回值为true时,表示继续向下执行; 
  5.      * 当其返回值为false时,会中断后续的所有操作。 
  6.      * @param request 
  7.      * @param response 
  8.      * @param handler 
  9.      * @return 
  10.      * @throws Exception 
  11.      */ 
  12.     @Override 
  13.     public boolean preHandle(HttpServletRequest request, 
  14.                              HttpServletResponse response, Object handler) throws Exception { 
  15.         System.out.println("CustomInterceptor...preHandle"); 
  16.         //对拦截的请求进行放行处理 
  17.         return true
  18.     } 
  19.  
  20.     /** 
  21.      * 该方法会在控制器方法调用之后,且解析视图之前执行。 
  22.      * 可以通过此方法对请求域中的模型和视图做出进一步的修改。 
  23.      * @param request 
  24.      * @param response 
  25.      * @param handler 
  26.      * @param modelAndView 
  27.      * @throws Exception 
  28.      */ 
  29.     @Override 
  30.     public void postHandle(HttpServletRequest request, 
  31.                            HttpServletResponse response, Object handler, 
  32.                            ModelAndView modelAndView) throws Exception { 
  33.         System.out.println("CustomInterceptor...postHandle"); 
  34.     } 
  35.  
  36.     /** 
  37.      * 该方法会在整个请求完成,即视图渲染结束之后执行。 
  38.      * 可以通过此方法实现一些资源清理、记录日志信息等工作。 
  39.      * @param request 
  40.      * @param response 
  41.      * @param handler 
  42.      * @param ex 
  43.      * @throws Exception 
  44.      */ 
  45.     @Override 
  46.     public void afterCompletion(HttpServletRequest request, 
  47.                                 HttpServletResponse response, Object handler, 
  48.                                 Exception ex) throws Exception { 
  49.         System.out.println("CustomInterceptor...afterCompletion"); 
  50.     } 

要使自定义的拦截器类生效,还需要在Spring MVC的配置文件中进行配置。

  1. <mvc:interceptors> 
  2.         <!--    全局拦截器,拦截所有请求    --> 
  3.         <bean class="com.nateshao.interceptor.CustomInterceptor"/>// 
  4.  
  5.         <mvc:interceptor> 
  6.         <!--   **配置,表示拦截所有路径  --> 
  7.             <mvc:mapping path="/**"/> 
  8.         <!--   配置不需要拦截的路径     --> 
  9.             <mvc:exclude-mapping path=""/> 
  10.  
  11.             <bean class="com.nateshao.interceptor.Interceptor1"/> 
  12.         </mvc:interceptor> 
  13.         <mvc:interceptor> 
  14.             <!--  /hello表示拦截所有以“/hello”结尾的路径   --> 
  15.             <mvc:mapping path="/hello"/> 
  16.             
  17.             <bean class="com.nateshao.interceptor.Interceptor2"/> 
  18.         </mvc:interceptor> 
  19.         ... 
  20.     </mvc:interceptors> 

注意:< mvc:interceptor >中的子元素必须按照上述代码的配置顺序进行编写,否则文件会报错。

2. 拦截器的执行流程

在运行程序时,拦截器的执行是有一定顺序的,该顺序与配置文件中所定义的拦截器的顺序相关。

单个拦截器,在程序中的执行流程如下图所示:

一篇学会Spring MVC 拦截器的骚操作

多个拦截器的执行流程

“多个拦截器(假设有两个拦截器Interceptor1和Interceptor2,并且在配置文件中, Interceptor1拦截器配置在前),在程序中的执行流程如下图所示:

一篇学会Spring MVC 拦截器的骚操作

3. 应用案例

案例说明 : 实现用户登录权限验证

“案例中,只有登录后的用户才能访问系统中的主页面,如果没有登录系统而直接访问主页面,则拦截器会将请求拦截,并转发到登录页面,同时在登录页面中给出提示信息。如果用户名或密码错误,也会在登录页面给出相应的提示信息。当已登录的用户在系统主页中单击“退出”链接时,系统同样会回到登录页面。

一篇学会Spring MVC 拦截器的骚操作

login.jsp

  1. <%@ page language="java" contentType="text/html; charset=UTF-8" 
  2.      pageEncoding="UTF-8"%> 
  3. <html> 
  4. <head> 
  5. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"
  6. <title>系统主页</title> 
  7. </head> 
  8. <body> 
  9.     当前用户:${USER_SESSION.username}   
  10.     <a href="${pageContext.request.contextPath }/logout">退出</a>   
  11. </body> 
  12. </html> 

LoginInterceptor.java

  1. package com.nateshao.interceptor; 
  2.  
  3. import com.nateshao.po.User
  4. import org.springframework.web.servlet.HandlerInterceptor; 
  5. import org.springframework.web.servlet.ModelAndView; 
  6. import javax.servlet.http.HttpServletRequest; 
  7. import javax.servlet.http.HttpServletResponse; 
  8. import javax.servlet.http.HttpSession; 
  9.  
  10. /** 
  11.  * @date Created by 邵桐杰 on 2021/10/22 12:50 
  12.  * @微信公众号 程序员千羽 
  13.  * @个人网站 www.nateshao.cn 
  14.  * @博客 https://nateshao.gitee.io 
  15.  * @GitHub https://github.com/nateshao 
  16.  * @Gitee https://gitee.com/nateshao 
  17.  * Description: 登录拦截器 
  18.  */ 
  19. public class LoginInterceptor implements HandlerInterceptor { 
  20.     @Override 
  21.     public boolean preHandle(HttpServletRequest request, 
  22.                              HttpServletResponse response, Object handler) throws Exception { 
  23.         // 获取请求的URL 
  24.         String url = request.getRequestURI(); 
  25.         // URL:除了login.jsp是可以公开访问的,其它的URL都进行拦截控制 
  26.         if (url.indexOf("/login") >= 0) { 
  27.             return true
  28.         } 
  29.         // 获取Session 
  30.         HttpSession session = request.getSession(); 
  31.         User user = (User) session.getAttribute("USER_SESSION"); 
  32.         // 判断Session中是否有用户数据,如果有,则返回true,继续向下执行 
  33.         if (user != null) { 
  34.             return true
  35.         } 
  36.         // 不符合条件的给出提示信息,并转发到登录页面 
  37.         request.setAttribute("msg""您还没有登录,请先登录!"); 
  38.         request.getRequestDispatcher("/WEB-INF/jsp/login.jsp"
  39.                 .forward(request, response); 
  40.         return false
  41.     } 
  42.  
  43.     @Override 
  44.     public void postHandle(HttpServletRequest request, 
  45.                            HttpServletResponse response, Object handler, 
  46.                            ModelAndView modelAndView) throws Exception { 
  47.     } 
  48.  
  49.     @Override 
  50.     public void afterCompletion(HttpServletRequest request, 
  51.                                 HttpServletResponse response, Object handler, Exception ex) 
  52.             throws Exception { 
  53.     } 

UserController.java

  1. package com.nateshao.controller; 
  2.  
  3. import com.nateshao.po.User
  4. import org.springframework.stereotype.Controller; 
  5. import org.springframework.ui.Model; 
  6. import org.springframework.web.bind.annotation.RequestMapping; 
  7. import org.springframework.web.bind.annotation.RequestMethod; 
  8. import javax.servlet.http.HttpSession; 
  9.  
  10. /** 
  11.  * @date Created by 邵桐杰 on 2021/10/22 12:47 
  12.  * @微信公众号 程序员千羽 
  13.  * @个人网站 www.nateshao.cn 
  14.  * @博客 https://nateshao.gitee.io 
  15.  * @GitHub https://github.com/nateshao 
  16.  * @Gitee https://gitee.com/nateshao 
  17.  * Description: 
  18.  */ 
  19. @Controller 
  20. public class UserController { 
  21.     /** 
  22.      * 向用户登录页面跳转 
  23.      */ 
  24.     @RequestMapping(value = "/login", method = RequestMethod.GET) 
  25.     public String toLogin() { 
  26.         return "login"
  27.     } 
  28.  
  29.     /** 
  30.      * 用户登录 
  31.      */ 
  32.     @RequestMapping(value = "/login", method = RequestMethod.POST) 
  33.     public String login(User user, Model model, HttpSession session) { 
  34.         // 获取用户名和密码 
  35.         String username = user.getUsername(); 
  36.         String password = user.getPassword(); 
  37.         // 此处模拟从数据库中获取用户名和密码后进行判断 
  38.         if (username != null && username.equals("nateshao"
  39.                 && password != null && password.equals("123456")) { 
  40.             // 将用户对象添加到Session 
  41.             session.setAttribute("USER_SESSION"user); 
  42.             // 重定向到主页面的跳转方法 
  43.             return "redirect:main"
  44.         } 
  45.         model.addAttribute("msg""用户名或密码错误,请重新登录!"); 
  46.         return "login"
  47.     } 
  48.  
  49.     /** 
  50.      * 向用户主页面跳转 
  51.      */ 
  52.     @RequestMapping(value = "/main"
  53.     public String toMain() { 
  54.         return "main"
  55.     } 
  56.  
  57.     /** 
  58.      * 退出登录 
  59.      */ 
  60.     @RequestMapping(value = "/logout"
  61.     public String logout(HttpSession session) { 
  62.         // 清除Session 
  63.         session.invalidate(); 
  64.         // 重定向到登录页面的跳转方法 
  65.         return "redirect:login"
  66.     } 

main.jsp

  1. <%@ page language="java" contentType="text/html; charset=UTF-8" 
  2.      pageEncoding="UTF-8"%> 
  3. <html> 
  4. <head> 
  5. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"
  6. <title>系统主页</title> 
  7. </head> 
  8. <body> 
  9.     当前用户:${USER_SESSION.username}   
  10.     <a href="${pageContext.request.contextPath }/logout">退出</a>   
  11. </body> 
  12. </html> 

验证

浏览器输入:http://localhost:8080/110_springmvc_interceptor_war_exploded/main

一篇学会Spring MVC 拦截器的骚操作

输入用户名密码

一篇学会Spring MVC 拦截器的骚操作

一篇学会Spring MVC 拦截器的骚操作

总结

这一篇文章主要对Spring MVC中的拦截器使用进行了详细讲解。

首先介绍了如何在Spring MVC项目中定义和配置拦截器,然后详细讲解了单个拦截器和多个拦截器的执行流程,最后通过一个用户登录权限验证的应用案例演示了拦截器的实际应用。

最后我们可以对Spring MVC中拦截器的定义和配置方式有一定的了解,能够熟悉拦截器的执行流程,并能够掌握拦截器的使用。

原文链接:https://mp.weixin.qq.com/s/uT0rNxU6Er7vEtiNBd4MSA

延伸 · 阅读

精彩推荐
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    这篇文章主要介绍了Java使用SAX解析xml的示例,帮助大家更好的理解和学习使用Java,感兴趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程Java实现抢红包功能

    Java实现抢红包功能

    这篇文章主要为大家详细介绍了Java实现抢红包功能,采用多线程模拟多人同时抢红包,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙...

    littleschemer13532021-05-16
  • Java教程20个非常实用的Java程序代码片段

    20个非常实用的Java程序代码片段

    这篇文章主要为大家分享了20个非常实用的Java程序片段,对java开发项目有所帮助,感兴趣的小伙伴们可以参考一下 ...

    lijiao5352020-04-06
  • Java教程小米推送Java代码

    小米推送Java代码

    今天小编就为大家分享一篇关于小米推送Java代码,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...

    富贵稳中求8032021-07-12
  • Java教程升级IDEA后Lombok不能使用的解决方法

    升级IDEA后Lombok不能使用的解决方法

    最近看到提示IDEA提示升级,寻思已经有好久没有升过级了。升级完毕重启之后,突然发现好多错误,本文就来介绍一下如何解决,感兴趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java BufferWriter写文件写不进去或缺失数据的解决

    Java BufferWriter写文件写不进去或缺失数据的解决

    这篇文章主要介绍了Java BufferWriter写文件写不进去或缺失数据的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java8中Stream使用的一个注意事项

    Java8中Stream使用的一个注意事项

    最近在工作中发现了对于集合操作转换的神器,java8新特性 stream,但在使用中遇到了一个非常重要的注意点,所以这篇文章主要给大家介绍了关于Java8中S...

    阿杜7482021-02-04
  • Java教程xml与Java对象的转换详解

    xml与Java对象的转换详解

    这篇文章主要介绍了xml与Java对象的转换详解的相关资料,需要的朋友可以参考下...

    Java教程网2942020-09-17