SpringMVC拦截器的使用

Spring MVC中的拦截器是一种可以在请求处理过程中对请求进行拦截和处理的机制。

拦截器可以用于执行一些公共的操作,例如日志记录、权限验证、数据转换等。在Spring MVC中,可以通过实现HandlerInterceptor接口来创建自定义的拦截器,并通过配置来指定拦截器的应用范围和顺序。

Spring MVC中的拦截器可以分为三种类型:

  1. 预处理拦截器(preHandle):在请求处理之前执行,可以用于做一些前置处理,例如权限验证、参数校验等。
  2. 后处理拦截器(postHandle):在请求处理之后、视图渲染之前执行,可以对处理结果进行修改或补充。
  3. 最终处理拦截器(afterCompletion):在请求处理完成之后执行,无论是否发生异常都会执行,用于资源清理等操作。

通过配置拦截器,我们可以灵活地控制请求的处理流程,并实现一些通用的功能,提高代码的复用性和可维护性。

SpringMVC拦截器 VS Servlet过滤器

Spring MVC拦截器和Servlet过滤器都可以用于在请求处理过程中对请求进行拦截和处理,但它们在实现机制和使用方式上有一些区别:

  1. 实现接口:

    • Spring MVC拦截器:Spring MVC的拦截器是基于HandlerInterceptor接口实现的,可以通过实现该接口来创建自定义的拦截器。
    • Servlet过滤器:Servlet过滤器是基于Filter接口实现的,可以通过实现该接口来创建自定义的过滤器。
  2. 使用范围:

    • Spring MVC拦截器:Spring MVC的拦截器主要用于拦截Spring MVC的请求处理流程,可以在控制器方法执行前后进行处理。
    • Servlet过滤器:Servlet过滤器可以在Servlet容器级别对所有请求进行过滤处理,不仅限于Spring MVC。
  3. 执行顺序:

    • Spring MVC拦截器:可以通过配置来指定拦截器的执行顺序,并且可以在拦截器链中控制多个拦截器的执行顺序。
    • Servlet过滤器:过滤器的执行顺序由其在web.xml文件中的配置顺序决定,无法控制多个过滤器的执行顺序。
  4. 依赖关系:

    • Spring MVC拦截器:Spring MVC拦截器依赖于Spring MVC框架,需要在Spring MVC配置文件中进行配置。
    • Servlet过滤器:Servlet过滤器是Servlet规范的一部分,不依赖于具体的框架,可以在web.xml文件中配置。

总的来说,Spring MVC拦截器更适合用于对Spring MVC请求进行处理和控制,而Servlet过滤器更适合用于对Servlet容器级别的请求进行过滤处理。根据具体的需求和场景,可以选择合适的方式来实现请求的拦截和处理。

SpringMVC拦截器的执行原理

Spring MVC的拦截器底层执行原理主要是通过HandlerExecutionChain来实现的。

当客户端发送请求时,DispatcherServlet会根据请求的URL找到对应的HandlerMapping,然后获取到处理该请求的HandlerExecutionChain,其中包括HandlerInterceptor拦截器链和HandlerMethod处理方法。

具体执行流程如下:

  1. DispatcherServlet根据请求的URL找到对应的HandlerMapping,获取到HandlerExecutionChain。
  2. 在HandlerExecutionChain中,包含了一个HandlerInterceptor拦截器链和一个HandlerMethod处理方法。
  3. DispatcherServlet会依次调用拦截器链中的每个拦截器的preHandle方法,在处理方法执行前进行拦截处理。
  4. 如果所有拦截器的preHandle方法都返回true,则执行HandlerMethod处理方法处理请求。
  5. 处理方法执行完毕后,DispatcherServlet会依次调用拦截器链中的每个拦截器的postHandle方法,在处理方法执行后、视图渲染前进行拦截处理。
  6. 最后,DispatcherServlet会依次调用拦截器链中的每个拦截器的afterCompletion方法,在视图渲染完毕后进行拦截处理,无论处理方法是否发生异常都会执行。

通过这样的拦截器链机制,Spring MVC可以灵活地控制请求的处理流程,实现对请求的拦截和处理。同时,开发者也可以自定义拦截器并通过配置来实现特定的业务逻辑。

SpringMVC配置拦截器

SpringMVC中的拦截器需要实现HandlerInterceptor接口

public class MyInterceptor implements HandlerInterceptor {

    /**
     * 处理请求的控制器方法前执行
     * @param request
     * @param response
     * @param handler
     * @return
     * @throws Exception
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("request=" + request + ",response=" + response + ",handler=" + handler);
	//返回true放行,false拦截
        return true;
    }

    /**
     * 在控制器方法处理请求后执行,控制器方法出现异常不执行
     * @param request
     * @param response
     * @param handler
     * @param modelAndView
     * @throws Exception
     */
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("MyInterceptor.postHandle");
    }

    /**
     * 视图渲染完后立即执行,不管控制器方法是否出现异常
     * @param request
     * @param response
     * @param handler
     * @param ex
     * @throws Exception
     */
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("MyInterceptor.afterCompletion");
    }
}

拦截器中三个默认方法说明:
preHandle:控制器方法执行之前执行preHandle(),其boolean类型的返回值表示是否拦截或放行,返回true为放行,即调用控制器方法;返回false表示拦截,即不调用控制器方法。
postHandle:控制器方法执行之后执行postHandle()。
afterComplation:处理完视图和模型数据,渲染视图完毕之后执行afterComplation()

SpringMVC的拦截器三种配置方式

方式1:使用bean标签

<mvc:interceptors>
    <bean class="com.evan.interceptor.myInterceptor"/>
</mvc:interceptors>

方式2:引入外部bean

<bean class="com.evan.interceptor.MyInterceptor" id="myInterceptor"/>
<mvc:interceptors>
	<ref bean="myInterceptor"/>
</mvc:interceptors>

方式3:使用注解方式

将拦截器的实现类注入到spring容器中

@Component //将实现类注入到容器中
public class MyInterceptor implements HandlerInterceptor {}

开启组件扫描

<context:component-scan base-package="com.evan.interceptor.MyInterceptor"/>

配置拦截器

<mvc:interceptors>
	<!-- 扫描组件从Spring容器中获取实现类对象,该对象默认是实现类的驼峰类名 -->
	<ref bean="myInterceptor"/>
</mvc:interceptors>

结论:
以上三种方式:都是对所有请求进行拦截
bean标签和ref标签配置的拦截器默认对DispatcherServlet处理的所有的请求进行拦截或放行。

排除指定的拦截请求

<mvc:interceptors>
    <!--<bean class="com.evan.interceptor.FirstInterceptor"/>-->
    <!--<ref bean="firstInterceptor"/>-->
    <mvc:interceptor>
       <!-- 配置需要拦截的请求的请求路径,/**表示所有请求 -->
        <mvc:mapping path="/**"/>
       <!-- 排除拦截的请求的请求路径-->
        <mvc:exclude-mapping path="/test/hello"/>
        <!-- 配置拦截器 -->
        <ref bean="firstInterceptor"/>
    </mvc:interceptor>
</mvc:interceptors>

注意:排除指定请求拦截,需要指定请求在拦截请求内部,拦截是向下兼容。
比如:拦截请求:/user/** 排除拦截需要在/user下 /user/get1 /user/get2 ...

配置类方式配置拦截器

1.默认拦截全部请求

@EnableWebMvc
@Configuration
@ComponentScan(basePackages = {"com.evan.interceptor"})
public class SpringMvcConfig implements WebMvcConfigurer {
    //添加拦截器
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
       //将拦截器添加到Springmvc环境,默认拦截所有Springmvc分发的请求
	registry.addInterceptor(new MyInterceptor());
    }
}

2.精确配置

@Override
public void addInterceptors(InterceptorRegistry registry) {
    //精准匹配,设置拦截器处理指定请求 路径可以设置一个或者多个,为项目下路径即可
    //可以使用/* 和 /** 进行模糊匹配
    registry.addInterceptor(new MyInterceptor())
	.addPathPatterns("/user/get1","/user/get2");
}

3.排除配置

//添加拦截器
@Override
public void addInterceptors(InterceptorRegistry registry) {
    //排除匹配,排除应该在匹配的范围内排除
    registry.addInterceptor(new MyInterceptor())
            .addPathPatterns("/user/**","/user/get/one")
            .excludePathPatterns("/user/get/two");
}

多个拦截器的执行顺序

通过观察源码:
1、若每个拦截器的preHandle()都返回true,则多个拦截器的执行顺序是按照在SpringMVC配置文件的配置顺序执行。

2、若多个拦截器中的某个拦截器的preHandle()返回false。preHandle()返回false和它之前的拦截器的preHandle()都会执行,postHandle()都不执行,返回false的拦截器之前的拦截器的afterComplation()会执行。

说明:
preHandle()会按照配置的顺序执行(由上而下),而postHandle()和afterComplation()会按照配置的反序执行(由下而上)。

原文地址:https://www.cnblogs.com/lisong0626/p/17999308

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


开发过程中是不可避免地会出现各种异常情况的,例如网络连接异常、数据格式异常、空指针异常等等。异常的出现可能导致程序的运行出现问题,甚至直接导致程序崩溃。因此,在开发过程中,合理处理异常、避免异常产生、以及对异常进行有效的调试是非常重要的。 对于异常的处理,一般分为两种方式: 编程式异常处理:是指在代
说明:使用注解方式实现AOP切面。 什么是AOP? 面向切面编程,利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。 通俗描述:不通过修改源代码方式,在主干功能里面添加新功能。 AOP底层使用动态代理。 AOP术语 连接点
Spring MVC中的拦截器是一种可以在请求处理过程中对请求进行拦截和处理的机制。 拦截器可以用于执行一些公共的操作,例如日志记录、权限验证、数据转换等。在Spring MVC中,可以通过实现HandlerInterceptor接口来创建自定义的拦截器,并通过配置来指定拦截器的应用范围和顺序。 S
在 JavaWeb 中,共享域指的是在 Servlet 中存储数据,以便在同一 Web 应用程序的多个组件中进行共享和访问。常见的共享域有四种:ServletContext、HttpSession、HttpServletRequest、PageContext。 ServletContext 共享域:
文件上传 说明: 使用maven构建web工程。 使用Thymeleaf技术进行服务器页面渲染。 使用ResponseEntity实现下载文件的功能。 @Controller public class FileDownloadAndUpload { @GetMapping(&quot;/file/d
创建初始化类,替换web.xml 在Servlet3.0环境中,Web容器(Tomcat)会在类路径中查找实现javax.servlet.ServletContainerInitializer接口的类,如果找到的话就用它来配置Servlet容器。 Spring提供了这个接口的实现,名为SpringS
在 Web 应用的三层架构中,确保在表述层(Presentation Layer)对数据进行检查和校验是非常重要的。正确的数据校验可以确保业务逻辑层(Business Logic Layer)基于有效和合法的数据进行处理,同时将错误的数据隔离在业务逻辑层之外。这有助于提高系统的健壮性、安全性和可维护
什么是事务? 事务(Transaction)是数据库操作最基本单元,逻辑上一组操作,要么都成功,要么都失败,如果操作之间有一个失败所有操作都失败 。 事务四个特性(ACID) 原子性 一组操作要么都成功,要么都失败。 一致性 一组数据从事务1合法状态转为事务2的另一种合法状态,就是一致。 隔离性 事
什么是JdbcTemplate? Spring 框架对 JDBC 进行封装,使用 JdbcTemplate 方便实现对数据库操作。 准备工作 引入jdbcTemplate的相关依赖: 案例实操 创建jdbc.properties文件,配置数据库信息 jdbc.driver=com.mysql.cj.
SpringMVC1.MVC架构MVC是模型(Model)、视图(View)、控制器(Controller)的简写,是一种软件设计规范是将业务逻辑、数据、显示分离的方法来写代码MVC主要作用是:降低了视图和业务逻辑之间的双向耦合MVC是一个架构模型,不是一种设计模式。1.model(模型)数据模型,提供要展示的数据,因此包
SpringMVC学习笔记1.SpringMVC应用1.1SpringMVC简介​SpringMVC全名叫SpringWebMVC,是⼀种基于Java的实现MVC设计模型的请求驱动类型的轻量级Web框架,属于SpringFrameWork的后续产品。​MVC全名是ModelViewController,是模型(model)-视图(view)-控制器(co
11.1数据回显基本用法数据回显就是当用户数据提交失败时,自动填充好已经输入的数据。一般来说,如果使用Ajax来做数据提交,基本上是没有数据回显这个需求的,但是如果是通过表单做数据提交,那么数据回显就非常有必要了。11.1.1简单数据类型简单数据类型,实际上框架在这里没有
一、SpringMVC简介1、SpringMVC中重要组件DispatcherServlet:前端控制器,接收所有请求(如果配置/不包含jsp)HandlerMapping:解析请求格式的.判断希望要执行哪个具体的方法.HandlerAdapter:负责调用具体的方法.ViewResovler:视图解析器.解析结果,准备跳转到具体的物
1.它们主要负责的模块Spring主要应用于业务逻辑层。SpringMVC主要应用于表现层。MyBatis主要应用于持久层。2.它们的核心Spring有三大核心,分别是IOC(控制反转),DI(依赖注入)和AOP(面向切面编程)。SpringMVC的核心是DispatcherServlet(前端控制器)。MyBatis的核心是ORM(对
3.注解开发Springmvc1.使用注解开发要注意开启注解支持,2.注解简化了,处理映射器和处理适配器,只用去管视图解析器即可案例代码:1.web.xml,基本不变可以直接拿去用<!--调用DispatcherServlet--><servlet><servlet-name>springmvc</servlet-name>
拦截器概述SpringMVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。开发者可以自己定义一些拦截器来实现特定的功能。**过滤器与拦截器的区别:**拦截器是AOP思想的具体应用。过滤器servlet规范中的一部分,任何javaweb工程都可以使用
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:context="http://www.springframework.org/schema/context"xmlns:mvc="http://www.springframework.org/schema/mvc"xmlns:xsi="
学习内容:1、SSH&SSM2、Spring3、Struts2&SpringMVC4、Hibernate&MyBatis学习产出:1.SSH和SSM都是有Spring框架的,他们两个差不多。2.Spring分为四个模块,持久层,表示层,检测层,还有核心层,核心层分为2个关键核心功能。分别为,控制反转(IOC),依赖注入(DI),和面向切面编程
一、SpringMVC项目无法引入js,css的问题具体原因是css和js等被SpringMVC拦截了:解决方案:在spring-mvc.xml中配置<mvc:default-servlet-handler/><?xmlversion="1.0"encoding="UTF-8"?><beansxmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
开发环境:Eclipse/MyEclipse、Tomcat8、Jdk1.8数据库:MySQL前端:JavaScript、jQuery、bootstrap4、particles.js后端:maven、SpringMVC、MyBatis、ajax、mysql读写分离、mybatis分页适用于:课程设计,毕业设计,学习等等系统介绍