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

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

服务器之家 - 编程语言 - Java教程 - 简单总结SpringMVC拦截器的使用方法

简单总结SpringMVC拦截器的使用方法

2021-09-17 09:27红旗下的小兵 Java教程

今天给大家带来的是关于SpringMVC拦截器的相关知识,文章围绕着SpringMVC拦截器的使用方法展开,文中有非常详细的介绍及代码示例,需要的朋友可以参考下

SpringMVC拦截器

拦截器类似于Filter过滤器,它是springMVC特有的,它可以预处理和后处理,我们可以定义一些拦截器来实现特定的业务。

过滤器与拦截器本质区别:

(1)拦截器时AOP思想的具体应用(一个横切面,直接切进请求响应中去)。

(2)拦截器时spring MVC特有的。

(3)拦截器只会拦截 访问控制器的方法,如果访问静态资源如:.jsp/html/css/image/js 时,它不会去拦截,而Filter过滤器无论什么都会去拦截。

自定义拦截器需要两步:

第一步:编写自定义类实现 HandlerInterceptor 接口,且必须重写方法;

第二步:在配置类中,注册拦截器,实现 WebMvcConfigurer接口,重写对应的方法;关于配置类                 我在这边文章有记录:http://www.zzvips.com/article/192463.html

(1)public boolean preHandle() {}

请求前处理的逻辑 - 前置。
方法返回值:返回布尔值,返回true表示可以执行后续代码,返回false程序会终止。

(2)public void postHandle(){}

请响应前处理的逻辑 - 后置。
方法返回值:无返回值。

目录:

简单总结SpringMVC拦截器的使用方法

  1. package com.lxc.springboot.interceptor;
  2.  
  3. import org.springframework.stereotype.Component;
  4. import org.springframework.web.servlet.HandlerInterceptor;
  5.  
  6. @Component
  7. public class MyInterceptor implements HandlerInterceptor {
  8. private static final Logger LOG = LoggerFactory.getLogger(LogInterceptor.class);
  9. @Override
  10. public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
  11. s
  12. // 拦截前的操作
  13. System.out.println("-----------前置拦截-----------");
  14. return true;
  15. }
  16.  
  17. @Override
  18. public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
  19. // 拦截后的操作
  20. System.out.println("------------后置拦截------------");
  21. }
  22.  
  23. @Override
  24. public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
  25. // 可以做一些清理工作
  26. }
  27. }

注册拦截器:

  1. package com.lxc.springboot.config;
  2.  
  3. import com.lxc.springboot.intercetor.MyInterceptor;
  4. import org.springframework.context.annotation.Configuration;
  5. import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
  6. import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
  7.  
  8. import javax.annotation.Resource;
  9.  
  10. /**
  11. * @扩展springMVC
  12. * 第一步:
  13. * @Configuration 注解的作用:让这个类变为配置类
  14. * 第二步:
  15. * 必须实现 WebMvcConfigurer 接口
  16. */
  17. @Configuration
  18. public class SpringMvcConfig implements WebMvcConfigurer {
  19. @Resource
  20. private MyInterceptor myInterceptor;
  21. @Override
  22. public void addInterceptors(InterceptorRegistry registry) {
  23. // addInterceptor():注册拦截器,参数是一个拦截器
  24. // addPathPatterns(): 路径映射,哪些路径需要被拦截,/** 全部拦截
  25. // excludePathPatterns(): 排除哪些路径,不会被拦截
  26. registry.addInterceptor(myInterceptor)
  27. .addPathPatterns("/**")
  28. .excludePathPatterns("/login");
  29. }
  30. }

简单总结SpringMVC拦截器的使用方法

小例子

跟Filter一样,记录接口的请求响应耗时:

  1. package com.lxc.springboot.interceptor;
  2.  
  3. import org.slf4j.Logger;
  4. import org.slf4j.LoggerFactory;
  5. import org.springframework.stereotype.Component;
  6. import org.springframework.web.servlet.HandlerInterceptor;
  7. import org.springframework.web.servlet.ModelAndView;
  8.  
  9. import javax.servlet.http.HttpServletRequest;
  10. import javax.servlet.http.HttpServletResponse;
  11.  
  12. /**
  13. * 这个是拦截器,与过滤器区别:
  14. *
  15. * 【【【【特别注意:增加拦截器,还需要在config中增加一个配置类!配置】】】】
  16. *
  17. * (1)拦截器是spring特有的,经常用于登录校验、权限验证、请求打印日志等等。
  18. * (2)拦截器不需要你手动调用后续代码执行,它是有两个方法的,且分开的,一个前,一个后
  19. * (3)而过滤器,我们会在打印日志的中间,使用filterChain.doFilter()方法去调用后续代码执行的!
  20. * (4)拦截器的 preHandle 前置处理方法,必须返回true,否则后续逻辑不会执行,整个业务也会结束!
  21. */
  22. @Component // 增加这个注解,让spring能扫描到这个类
  23. public class LogInterceptor implements HandlerInterceptor {
  24. private static final Logger LOG = LoggerFactory.getLogger(LogInterceptor.class);
  25. @Override
  26. public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
  27. LOG.info("【全局拦截器】");
  28. LOG.info("*********** InterceptorLog日志开始 *********** ");
  29. LOG.info("* 请求地址: {}, 方法: {}", request.getRequestURL().toString(), request.getMethod());
  30. LOG.info("* 远程地址: {}, 域名: {}, 端口: {}", request.getRemoteAddr(), request.getRemoteHost(), request.getRemotePort());
  31. long startTime = System.currentTimeMillis();
  32. request.setAttribute("boot-responseTime", startTime);
  33. return true;
  34. }
  35.  
  36. @Override
  37. public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
  38. // request.getAttribute("boot-responseTime") 返回的是Object
  39. long startTimed = (long) request.getAttribute("boot-responseTime");
  40. LOG.info(" *********** InterceptorLog 结束,耗时: {} ms *********** ", System.currentTimeMillis() - startTimed);
  41. }
  42. }

在配置类中注册拦截器:

  1. package com.lxc.springboot.config;
  2.  
  3. import com.lxc.springboot.intercetor.LogInterceptor;
  4. import com.lxc.springboot.intercetor.MyInterceptor;
  5. import org.springframework.context.annotation.Configuration;
  6. import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
  7. import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
  8.  
  9. import javax.annotation.Resource;
  10.  
  11. @Configuration
  12. public class SpringMvcConfig implements WebMvcConfigurer {
  13. @Resource
  14. private MyInterceptor myInterceptor;
  15. @Resource
  16. private LogInterceptor logInterceptor;
  17.  
  18. @Override
  19. public void addInterceptors(InterceptorRegistry registry) {
  20. registry.addInterceptor(logInterceptor)
  21. .addPathPatterns("/**")
  22. .excludePathPatterns("/login");
  23. }
  24.  
  25. }

测试:

简单总结SpringMVC拦截器的使用方法

到此这篇关于简单总结SpringMVC拦截器的使用方法的文章就介绍到这了,更多相关SpringMVC拦截器内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_42778001/article/details/118262888

延伸 · 阅读

精彩推荐
  • Java教程小米推送Java代码

    小米推送Java代码

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

    富贵稳中求8032021-07-12
  • Java教程xml与Java对象的转换详解

    xml与Java对象的转换详解

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

    Java教程网2942020-09-17
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

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

    大行者10067412021-08-30
  • Java教程Java BufferWriter写文件写不进去或缺失数据的解决

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

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

    spcoder14552021-10-18
  • Java教程Java实现抢红包功能

    Java实现抢红包功能

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

    littleschemer13532021-05-16
  • Java教程Java8中Stream使用的一个注意事项

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

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

    阿杜7472021-02-04
  • Java教程20个非常实用的Java程序代码片段

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

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

    lijiao5352020-04-06
  • Java教程升级IDEA后Lombok不能使用的解决方法

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

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

    程序猿DD9332021-10-08