Spring MVC中拦截器小结

2024-08-27 14:08
文章标签 java spring 拦截器 mvc 小结

本文主要是介绍Spring MVC中拦截器小结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在spring mvc中,拦截器其实比较简单了,下面简单小结并demo下。

preHandle:预处理回调方法,实现处理器的预处理(如登录检查),第三个参数为响应的处理器(如我们上一章的Controller实现);
     返回值:true表示继续流程(如调用下一个拦截器或处理器);
             false表示流程中断(如登录检查失败),不会继续调用其他的拦截器或处理器,此时我们需要通过response来产生响应;
postHandle:后处理回调方法,实现处理器的后处理(但在渲染视图之前),此时我们可以通过modelAndView(模型和视图对象)对模型数据进行处理或对视图进行处理,modelAndView也可能为null。
afterCompletion:整个请求处理完毕回调方法,即在视图渲染完毕时回调,如性能监控中我们可以在此记录结束时间并输出消耗时间,还可以进行一些资源清理,类似于try-catch-finally中的finally,但仅调用处理器执行链中preHandle返回true的拦截器的afterCompletion。

  下面是简单的DEMO

1)
Java代码   收藏代码
  1. @Controller  
  2. public class HelloWorldController {  
  3.   
  4.       
  5.     @RequestMapping(value = "/hello", method = RequestMethod.GET)  
  6.     public String sayHello() {  
  7.         return "hello";  
  8.     }  
  9. }  

   这个是一个简单的controller了


2) 拦截器
 
Java代码   收藏代码
  1. public class HelloWorldInterceptor implements HandlerInterceptor  {  
  2. @Override  
  3. public boolean preHandle(HttpServletRequest request,  
  4.         HttpServletResponse response, Object handler) throws Exception {  
  5.       
  6.     System.out.println("Pre-handle");  
  7.       
  8.     return false;  
  9. }  
  10.   
  11. @Override  
  12. public void postHandle(HttpServletRequest request,  
  13.         HttpServletResponse response, Object handler,  
  14.         ModelAndView modelAndView) throws Exception {  
  15.     System.out.println("Post-handle");  
  16. }  
  17.   
  18. @Override  
  19. public void afterCompletion(HttpServletRequest request,  
  20.         HttpServletResponse response, Object handler, Exception ex)  
  21.         throws Exception {  
  22.     System.out.println("After completion handle");  
  23. }  


3) spring mvc配置文件
 
Java代码   收藏代码
  1. <?xml  version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.     xmlns:context="http://www.springframework.org/schema/context"  
  5.     xmlns:mvc="http://www.springframework.org/schema/mvc"  
  6.     xsi:schemaLocation="http://www.springframework.org/schema/beans   
  7.         http://www.springframework.org/schema/beans/spring-beans.xsd  
  8.         http://www.springframework.org/schema/context   
  9.         http://www.springframework.org/schema/context/spring-context.xsd  
  10.         http://www.springframework.org/schema/mvc   
  11.         http://www.springframework.org/schema/mvc/spring-mvc.xsd">  
  12.           
  13.     <context:annotation-config />  
  14.     <context:component-scan base-package="net.viralpatel.spring3.controller"/>  
  15.       
  16.     <mvc:interceptors>  
  17.       <bean class="net.viralpatel.spring3.interceptor.HelloWorldInterceptor" />  
  18.     </mvc:interceptors>   
  19.       
  20.   <bean id="jspViewResolver"  
  21.     class="org.springframework.web.servlet.view.InternalResourceViewResolver">  
  22.         <property name="viewClass"  
  23.             value="org.springframework.web.servlet.view.JstlView" />  
  24.         <property name="prefix" value="/WEB-INF/jsp/" />  
  25.         <property name="suffix" value=".jsp" />  
  26.   </bean>  
  27. </beans>  


  其中使用了<mvc:interceptors>注册了拦截器

4) 运行后,输出:
Pre-handle
Post-handle
After completion handle

   如果在拦截器中的prehandler中返回false,则根本不会渲染到view层了,直接只输出:
Pre-handle,假如注册了两个拦截器,
Java代码   收藏代码
  1. <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping">    
  2.     <property name="interceptors">    
  3.         <list>    
  4.            <ref bean="handlerInterceptor1"/>    
  5.           <ref bean="handlerInterceptor2"/>    
  6.         </list>    
  7.     </property>    
  8. </bean>    

   
  则拦截器的执行顺序就是此处添加拦截器的顺序;会输出:
HandlerInterceptor1 preHandle 
HandlerInterceptor2 preHandle 
 
HandlerInterceptor2 postHandle 
HandlerInterceptor1 postHandle 

HandlerInterceptor2 afterCompletion 
HandlerInterceptor1 afterCompletion 
    总结下,就是在哪个拦截器的prehandler方法中返回false,则该拦截器posthandler和aftercomplete方法了。
 
参考:http://jinnianshilongnian.iteye.com/blog/1670856

这篇关于Spring MVC中拦截器小结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1111887

相关文章

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏