配置前端控制器

article/2025/6/23 6:13:52

一、DispatcherServlet 详解

在使用 Spring MVC 框架构建 Web 应用时,DispatcherServlet是整个请求处理流程的核心。本文将深入解析DispatcherServlet的作用、工作原理及其在 Spring MVC 架构中的关键地位。

1.DispatcherServlet 是什么?

DispatcherServlet是 Spring MVC 框架的前端控制器(Front Controller),它是一个 Servlet(继承自HttpServlet),负责接收所有 HTTP 请求并协调整个请求处理流程。其核心作用类似于一个中央调度器,将请求分发给合适的处理器(Controller)进行处理,并管理视图渲染和响应返回。

在 web.xml 中的典型配置如下:

<servlet><servlet-name>dispatcher</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><param-name>contextConfigLocation</param-name><param-value>/WEB-INF/dispatcher-servlet.xml</param-value></init-param><load-on-startup>1</load-on-startup>
</servlet><servlet-mapping><servlet-name>dispatcher</servlet-name><url-pattern>/</url-pattern>
</servlet-mapping>

2.DispatcherServlet 的工作原理

⑴. 核心设计模式:前端控制器模式

DispatcherServlet采用前端控制器模式(Front Controller Pattern),所有请求都由同一个 Servlet 接收和处理。这种模式的优势在于:

  • 统一请求入口,简化应用架构
  • 便于实现通用功能(如权限检查、日志记录)
  • 降低组件间耦合度

⑵. 请求处理流程

当客户端发送 HTTP 请求时,DispatcherServlet的处理流程大致如下:

  1. 接收请求:所有匹配url-pattern的请求都被发送到DispatcherServlet
  2. 映射处理器:通过HandlerMapping找到处理该请求的 Controller
  3. 调用处理器:通过HandlerAdapter调用 Controller 的处理方法
  4. 处理业务逻辑:Controller 执行相应的业务逻辑并返回ModelAndView
  5. 解析视图:通过ViewResolver将逻辑视图名解析为具体的 View
  6. 渲染视图:将 Model 数据填充到 View 中并返回响应给客户端

这个流程可以用以下时序图表示:

客户端请求 -> DispatcherServlet -> HandlerMapping -> Controller <- ModelAndView        <- ViewResolver    <- View

3.DispatcherServlet 的关键组件

DispatcherServlet的强大功能依赖于多个协作组件,这些组件在初始化时会自动注册或通过配置文件显式注册:

⑴. HandlerMapping(处理器映射器)

负责将请求映射到具体的处理器(Controller)。常见实现:

  • BeanNameUrlHandlerMapping:按 Bean 名称映射 URL
  • RequestMappingHandlerMapping:基于@RequestMapping注解映射(Spring MVC 默认)

⑵. HandlerAdapter(处理器适配器)

负责调用具体的处理器。常见实现:

  • SimpleControllerHandlerAdapter:处理实现Controller接口的处理器
  • RequestMappingHandlerAdapter:处理基于注解的处理器(Spring MVC 默认)

⑶. HandlerExceptionResolver(异常处理器)

处理请求处理过程中抛出的异常。常见实现:

  • SimpleMappingExceptionResolver:将异常映射到视图
  • ExceptionHandlerExceptionResolver:处理@ExceptionHandler注解的方法

⑷. ViewResolver(视图解析器)

将逻辑视图名解析为具体的 View 对象。常见实现:

  • InternalResourceViewResolver:解析 JSP 视图
  • ThymeleafViewResolver:解析 Thymeleaf 模板
  • JsonViewResolver:返回 JSON 格式响应

⑸. LocaleResolver(区域解析器)

解析客户端的区域信息,用于国际化支持。常见实现:

  • AcceptHeaderLocaleResolver:基于 HTTP 请求头的 Accept-Language
  • CookieLocaleResolver:基于 Cookie 保存区域信息

⑹. ThemeResolver(主题解析器)

解析应用的主题。常见实现:

  • FixedThemeResolver:固定主题
  • CookieThemeResolver:基于 Cookie 的主题

⑺. MultipartResolver(文件上传解析器)

处理文件上传请求。常见实现:

  • StandardServletMultipartResolver:基于 Servlet 3.0 的文件上传
  • CommonsMultipartResolver:基于 Apache Commons FileUpload

4.DispatcherServlet 的初始化过程

当 Web 应用启动时,DispatcherServlet会进行初始化,主要步骤包括:

  1. 创建 WebApplicationContext

    • 加载 Spring 配置文件(如dispatcher-servlet.xml或 Java 配置类)
    • 创建并注册 Spring MVC 所需的各种组件
  2. 初始化策略组件

    • 检查并注册HandlerMappingHandlerAdapter等组件
    • 如果没有显式配置,会使用默认组件
  3. 注册到 Servlet 容器

    • 作为普通 Servlet 注册到 Servlet 容器中
    • 接收所有匹配url-pattern的请求

5.DispatcherServlet 的配置方式

⑴. 传统 XML 配置

web.xml中配置DispatcherServlet

<servlet><servlet-name>dispatcher</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><param-name>contextConfigLocation</param-name><param-value>/WEB-INF/dispatcher-servlet.xml</param-value></init-param><load-on-startup>1</load-on-startup>
</servlet>

⑵. Java 配置(Spring 3.0+)

使用WebApplicationInitializer接口:

public class AppInitializer implements WebApplicationInitializer {@Overridepublic void onStartup(ServletContext servletContext) {// 创建根应用上下文AnnotationConfigWebApplicationContext rootContext = new AnnotationConfigWebApplicationContext();rootContext.register(AppConfig.class);// 创建DispatcherServlet应用上下文AnnotationConfigWebApplicationContext dispatcherContext = new AnnotationConfigWebApplicationContext();dispatcherContext.register(DispatcherConfig.class);// 注册DispatcherServletServletRegistration.Dynamic dispatcher = servletContext.addServlet("dispatcher", new DispatcherServlet(dispatcherContext));dispatcher.setLoadOnStartup(1);dispatcher.addMapping("/");}
}

⑶.Spring Boot 自动配置

Spring Boot 会自动配置DispatcherServlet,默认映射路径为/,无需手动配置。

二、<init-param> 标签

<init-param> 标签中的 contextConfigLocation 参数是 Spring MVC 中 DispatcherServlet 的核心配置项,它的作用是指定 Spring MVC 应用上下文的配置文件位置。下面详细解释其功能和用法:

1.核心作用:加载 Spring MVC 配置

当 DispatcherServlet 初始化时,它会创建一个 WebApplicationContext(Spring 的应用上下文),并从指定的配置文件中加载 Bean 定义。contextConfigLocation 参数就是用来告诉 DispatcherServlet 从哪里读取这些配置文件。

示例配置

<servlet><servlet-name>dispatcher</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><param-name>contextConfigLocation</param-name><param-value>classpath:springmvc.xml</param-value> <!-- 指定配置文件位置 --></init-param><load-on-startup>1</load-on-startup>
</servlet>

三、总结

这个配置文件片段是典型的 Spring MVC 框架前端控制器(DispatcherServlet)的配置,位于web.xml中(Servlet 3.0 + 之前的标准 Web 应用配置文件)。我来为你解析其核心作用和配置项:

配置的核心功能

这段配置的主要作用是注册 Spring MVC 的前端控制器DispatcherServlet,并将其映射到所有 URL 请求(/)。这是 Spring MVC 应用的基础配置,负责接收所有 HTTP 请求并分发给相应的处理器。

关键配置项解析

1.Servlet 注册

<servlet><servlet-name>springmvc</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>...
</servlet>
  • servlet-name:定义 Servlet 的名称,用于后续映射和引用
  • servlet-class:指定 Spring MVC 的核心前端控制器类

2.配置文件位置

<init-param><param-name>contextConfigLocation</param-name><param-value>classpath:springmvc.xml</param-value>
</init-param>
  • 指定 Spring MVC 的配置文件路径为classpath:springmvc.xml
  • 这个文件通常包含控制器 (Controller)、视图解析器 (ViewResolver)、拦截器 (Interceptor) 等配置

3.启动加载优先级

<load-on-startup>1</load-on-startup>
  • 值为1表示在 Web 容器启动时立即初始化这个 Servlet
  • 提高首次请求的响应速度(避免首次请求时才初始化)

4.URL 映射

<servlet-mapping><servlet-name>springmvc</servlet-name><url-pattern>/</url-pattern>
</servlet-mapping>
  • springmvc这个 Servlet 映射到所有 URL(/
  • 意味着所有 HTTP 请求都会先到达DispatcherServlet

工作原理

当客户端发送请求到应用时:

  1. 所有请求首先被DispatcherServlet接收
  2. DispatcherServlet根据请求 URL 和 HandlerMapping 找到对应的 Controller
  3. Controller 处理请求并返回 ModelAndView
  4. DispatcherServlet 根据 ViewResolver 将逻辑视图名解析为实际视图
  5. 最终将响应返回给客户端

注意事项

  1. /*的区别:使用/而不是/*,避免与 JSP 请求冲突(/*会拦截 JSP 请求导致无法正确渲染)
  2. 配置文件位置:确保springmvc.xml存在于类路径根目录下
  3. 其他必要配置:这个配置只是基础,完整的 MVC 功能还需要在springmvc.xml中配置视图解析器、注解扫描等


http://www.hkcw.cn/article/LmSEkZutIk.shtml

相关文章

使用PowerBI个人网关定时刷新数据

使用PowerBI个人网关定时刷新数据 PowerBI desktop连接mysql&#xff0c;可以设置定时刷新数据或在PowerBI服务中手动刷新数据,步骤如下&#xff1a; 第一步&#xff1a; 下载网关。以个人网关为例&#xff0c;如图 第二步&#xff1a; 双击网关&#xff0c;点击下一步&…

Dest建筑能耗模拟仿真功能简介

Dest建筑能耗模拟仿真功能简介 全球建筑能耗占终端能源消费的30%以上&#xff0c;掌握建筑能耗模拟是参与绿色建筑认证&#xff08;如LEED、WELL&#xff09;、超低能耗设计、既有建筑节能改造的必备能力。DEST作为国内主流建筑能耗模拟工具&#xff0c;广泛应用于设计院、咨询…

Vue2+Vuex通过数组动态生成store数据(分组模式)

在项目开发中,将数据集中存储在Vuex的store中,能便于数据的统一管理和维护。开发者可以在一个地方对数据进行操作和更新,以避免在组件中分散管理数据带来的混乱和复杂性。 对于状态数据较多情况下,界面操作数据又是数组结构,因业务需求,数组内每个元素都需要单独定义一个…

生成式AI模型学习笔记

文章目录 生成式AI模型1. 定义2. 生成式模型与判别式模型3. 深度生成式模型的类型3.1 能量模型3.2 变分自编码3.2.1 变分自编码器&#xff08;Variational Autoencoder, VAE&#xff09;简介3.2.2 代码示例&#xff08;以 PyTorch 为例&#xff09; 3.3 生成对抗网络3.4 流模型…

DAY 16 numpy数组与shap深入理解

一、NumPy 数组基础笔记 1. 理解数组的维度 &#xff08;Dimensions&#xff09; NumPy 数组的维度 &#xff08;Dimension&#xff09; 或称为 轴 &#xff08;Axis&#xff09; 的概念&#xff0c;与我们日常理解的维度非常相似。 直观判断&#xff1a; 数组的维度层数通常…

Maven 安装与配置指南(适用于 Windows、Linux 和 macOS)

Apache Maven 是一款广泛应用于 Java 项目的项目管理和构建工具。 本文提供在 Windows、Linux 和 macOS 系统上安装与配置 Maven 的详细步骤&#xff0c;旨在帮助开发者快速搭建高效的构建环境。 一、前置条件&#xff1a;安装 Java Development Kit (JDK) Maven 依赖于 Java …

Java对象克隆:从浅到深的奥秘

浅克隆与深克隆在Java中的应用及区别 核心概念 浅克隆 复制对象时仅克隆基本数据类型字段&#xff0c;引用类型字段共享原对象引用。实现方式&#xff1a; class Person implements Cloneable {String name;Address address; // 引用类型字段Overrideprotected Object clone…

【HW系列】—日志介绍

文章目录 一、日志介绍二、Apache日志详解1. 日志存放位置2. 日志类型3. 日志级别4. 常用日志分析命令&#xff08;Linux环境&#xff09; 三、IIS日志详解四、日志分析工具&#xff1a;360星图 一、日志介绍 为什么要使用日志 故障诊断&#xff1a;快速定位系统错误根源安全审…

cuda_fp8.h错误

现象&#xff1a; cuda_fp8.h错误 原因&#xff1a; CUDA Toolkit 小于11.8,会报fp8错误&#xff0c;因此是cuda工具版本太低。通过nvcc --version查看 CUDA Toolkit 是 NVIDIA 提供的一套 用于开发、优化和运行基于 CUDA 的 GPU 加速应用程序的工具集合。它的核心作用是让开发…

内容中台构建数字化管理新路径

数字化内容管理核心架构 现代企业数字化内容管理的核心架构依托于动态元数据架构构建策略与多源数据智能整合体系的双重支撑。通过建立三层架构模型——数据采集层、逻辑处理层与应用服务层&#xff0c;系统能够实现跨平台内容资产的统一索引与语义关联。其中&#xff0c;Bakl…

【连载21】基础智能体的进展与挑战综述-交互风险

20. 智能体外部安全性&#xff1a;交互风险 随着人工智能智能体的发展以及与日益复杂的环境互动&#xff0c;与这些互动相关的安全风险已成为一个关键问题。本章聚焦于人工智能智能体与记忆系统、物理和数字环境及其他智能体的互动。这些互动使人工智能智能体面临各种脆弱性&a…

【Day41】

DAY 41 简单CNN 知识回顾 数据增强卷积神经网络定义的写法batch归一化&#xff1a;调整一个批次的分布&#xff0c;常用与图像数据特征图&#xff1a;只有卷积操作输出的才叫特征图调度器&#xff1a;直接修改基础学习率 卷积操作常见流程如下&#xff1a; 1. 输入 → 卷积层 →…

C++:参数传递方法(Parameter Passing Methods)

目录 1. 值传递&#xff08;Pass by Value&#xff09; 2. 地址传递&#xff08;Pass by Address&#xff09; 3. 引用传递&#xff08;Pass by Reference&#xff09; 数组作为函数参数&#xff08;Array as Parameter&#xff09; 数组作为函数返回值 什么是函数&#xff…

【iOS】方法交换

方法交换 method-swizzling是什么相关API方法交换的风险method-swizzling使用过程中的一次性问题在当前类中进行方法交换类方法的方法交换 方法交换的应用 method-swizzling是什么 method-swizzling的含义是方法交换&#xff0c;他的主要作用是在运行的时候将一个方法的实现替…

GoogLeNet网络模型

GoogLeNet网络模型 诞生背景 在2014年的ImageNet图像识别挑战赛中&#xff0c;一个GoogLeNet的网络架构大放异彩&#xff0c;与VGG不同的是&#xff0c;VGG用的是3*3的卷积&#xff0c;而GoogLeNet从1*1到7*7的卷积核都用&#xff0c;也就是使用不同大小的卷积核组合。 网络…

Linux:动静态库

一&#xff1a;什么是库 库是写好的&#xff0c;现有的&#xff0c;成熟的可以复用的代码。现实中每个程序都要依赖很多基础的底层库&#xff0c;不可能每个人都从零开始写&#xff0c;因此库的存在一样非同寻常 本质上库是一种可执行代码的二进制形式&#xff0c;可以被操作…

【图像处理入门】2. Python中OpenCV与Matplotlib的图像操作指南

一、环境准备 import cv2 import numpy as np import matplotlib.pyplot as plt# 配置中文字体显示&#xff08;可选&#xff09; plt.rcParams[font.sans-serif] [SimHei] plt.rcParams[axes.unicode_minus] False二、图像的基本操作 1. 图像读取、显示与保存 使用OpenCV…

设计模式——装饰器设计模式(结构型)

摘要 文中主要介绍了装饰器设计模式&#xff0c;它是一种结构型设计模式&#xff0c;可在不改变原有类代码的情况下&#xff0c;动态为对象添加额外功能。文中详细阐述了装饰器模式的角色、结构、实现方式、适合场景以及实战示例等内容&#xff0c;还探讨了其与其他设计模式的…

生活小记啊

最近生活上的事情还是蛮多的&#xff0c;想到哪写到哪。 工作 三月的某个周六&#xff0c;正在加班写技术方案&#xff0c;大晚上写完了听到调动通知&#xff0c;要去新的团队了。 还是蛮不舍的&#xff0c;看着产品从无到有&#xff0c;一路走过来&#xff0c;倾注了不少感…

【android bluetooth 案例分析 04】【Carplay 详解 2】【Carplay 连接之手机主动连车机】

1. 背景 在【android bluetooth 案例分析 04】【Carplay 详解 1】【CarPlay 在车机侧的蓝牙通信原理与角色划分详解】中我们从整理上介绍了车机中 carplay 相关基础概念。 本节 将详细分析 iphone手机主动 连接 车机carplay 这一过程。 先回顾一下 上一节&#xff0c; carpla…