【Spring 篇】SpringMVC拦截器:给你的应用增添色彩

2024-03-18 13:52

本文主要是介绍【Spring 篇】SpringMVC拦截器:给你的应用增添色彩,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

嗨,亲爱的小伙伴们!欢迎来到这段关于SpringMVC拦截器的奇妙之旅。今天我们要一探究竟,深入挖掘拦截器的神秘面纱,看看它是如何在你的应用中悄然发挥作用的。别怕,我会用最通俗易懂的语言,一步一步带你走进这个充满色彩的世界。

什么是拦截器?

首先,我们来谈谈拦截器是个啥玩意。想象一下,拦截器就像是应用的守护神,能够在请求的各个阶段插上一脚。别被这个高大上的名字吓到,实际上它就是一位灵活而强大的小助手。

拦截器的主要职责包括:

  • 预处理请求: 在请求被处理之前,你可以在这个阶段做些事情,比如检查用户是否登录、记录一些日志等。
  • 后处理请求: 在Controller处理完请求,视图还未渲染之前,你可以再搞点事情,比如修改ModelAndView,再次记录一些日志什么的。
  • 请求完成后处理: 整个请求处理完成后,无论成功还是失败,你还有机会进行一些资源清理的操作。

为什么需要拦截器?

好奇心作祟,你可能想问为啥我们需要拦截器呢?很简单!拦截器的存在使得我们能够在请求的各个时刻灵活地插入自己的逻辑。比如,你可以在用户请求某个路径时,在请求前检查用户的登录状态,或者在请求后记录请求的处理时间。这让我们的应用更加灵活、可控。

如何配置拦截器?

配置拦截器其实非常简单。首先,我们需要创建一个类,实现HandlerInterceptor接口。这个接口定义了三个方法:preHandlepostHandleafterCompletion,分别对应请求处理前、请求处理后和请求完成后的时刻。看个简单的例子:

public class MyInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {// 在请求处理前执行,返回true表示继续执行,返回false中断执行// 可以进行身份验证、日志记录等操作return true;}@Overridepublic void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {// 在请求处理后但未渲染视图时执行// 可以修改ModelAndView,记录日志等操作}@Overridepublic void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {// 在请求完成后执行,无论请求成功还是失败都会执行// 可以进行资源清理等操作}
}

然后,我们在配置文件(通常是springmvc-servlet.xml)中进行配置,将拦截器添加到拦截器链中。比如:

<mvc:interceptors><mvc:interceptor><mvc:mapping path="/**"/> <!-- 拦截所有路径 --><bean class="com.example.MyInterceptor"/></mvc:interceptor>
</mvc:interceptors>

这样,我们就配置了一个简单的拦截器。当用户请求任何路径时,MyInterceptor中的方法就会被调用。

拦截器的执行流程

理解拦截器的执行流程对于掌握它的工作原理非常关键。以下是拦截器的基本执行流程:

  1. DispatcherServlet收到请求: 当用户发送请求时,DispatcherServlet是第一个感知到的。
  2. 拦截器的preHandle方法: 在请求进入Controller之前,拦截器的preHandle方法会被调用。在这个时刻,我们可以进行一些预处理,比如身份验证、日志记录等。
  3. Controller处理请求: 请求通过拦截器后,进入Controller进行处理。
  4. 拦截器的postHandle方法: 在Controller处理完请求,返回ModelAndView之前,拦截器的postHandle方法会被调用。在这个时刻,我们可以修改ModelAndView,记录日志等。
  5. 视图渲染: ModelAndView包含了Controller处理后的结果,然后进入视图层进行渲染。
  6. 拦截器的afterCompletion方法: 整个请求处理完成后,无论成功还是失败,拦截器的afterCompletion方法都会被调用。在这个时刻,我们可以进行一些资源清理的操作。

实战演练

为了更好地理解拦截器,让我们通过一个实际例子来演示。假设我们要在用户请求任何路径时,记录请求的处理时间并打印出来。首先,我们修改拦截器的postHandle方法:

@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {long startTime = (long) request.getAttribute("startTime");long endTime = System.currentTimeMillis();long processingTime = endTime - startTime;System.out.println("Request processing time: " + processingTime + " ms");
}

接下来,在preHandle方法中记录请求开始时间:

@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {long startTime = System.currentTimeMillis();request.setAttribute("startTime", startTime);return true;
}

这样,每次用户请求进入拦截器时,我们就记录了请求的开始时间。当请求处理完后,postHandle方法会被调用,我们计算出请求的处理时间并打印出来。

小结

通过这篇博客,我们深入了解了SpringMVC拦截器的原理和用法。拦截器是一个非常灵活的工具,可以在请求的各个时刻插入自定义的逻辑,实现对请求的精细控制。通过实例演示,我们了解了拦截器的配置和执行流程,为使用拦截器提供了一个清晰的指南。希望这篇博客对你理解和使用SpringMVC拦截器有所帮助!如果你有任何问题或建议,欢迎在评论区留言。祝你在编码的路上越走越远,愉快编码!

作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

这篇关于【Spring 篇】SpringMVC拦截器:给你的应用增添色彩的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory