28、請求處理-【源碼分析】-請求映射原理

28、請求處理-【源碼分析】-請求映射原理

Spring Boot 的請求映射原理主要基于 Spring MVC 框架,通過 `DispatcherServlet` 前端控制器實現。以下是詳細的請求映射過程:

### 1. 請求進入 `DispatcherServlet`

當客戶端發送請求時,首先由 `DispatcherServlet` 接收。`DispatcherServlet` 是 Spring MVC 的核心,負責處理所有進入應用的請求。

### 2. 查找處理器映射 (`HandlerMapping`)

`DispatcherServlet` 調用 `getHandler(HttpServletRequest request)` 方法,遍歷配置的 `HandlerMapping` 列表,查找能夠處理當前請求的處理器。

#### `HandlerMapping` 類型

Spring Boot 默認配置了多個 `HandlerMapping`:

- **`RequestMappingHandlerMapping`**:最重要的映射器,負責處理 `@RequestMapping` 注解標記的控制器方法。保存了所有 `@RequestMapping` 注解與處理方法的映射關系。

- **`WelcomePageHandlerMapping`**:處理根路徑 (`/`) 請求,映射到默認的歡迎頁面(如 `index.html`)。

- **`BeanNameUrlHandlerMapping`**:將 Bean 名稱作為 URL 進行映射。

- **`SimpleUrlHandlerMapping`**:通過配置文件顯式定義的簡單 URL 映射。

- **`RouterFunctionMapping`**:處理基于函數式編程的 WebFlux 路由。

### 3. 匹配請求路徑和處理方法

`RequestMappingHandlerMapping` 根據請求的路徑、HTTP 方法、請求參數等信息,匹配最適合的處理方法。匹配規則包括:

- **URL 路徑匹配**:精確匹配、通配符匹配 (`*`)、路徑變量 (`/{variable}`)、正則表達式 (`/{regex:pattern}`)。

- **HTTP 方法匹配**:`GET`、`POST`、`PUT`、`DELETE` 等。

- **請求頭匹配**:通過 `@RequestMapping` 的 `headers` 屬性指定。

- **請求參數匹配**:通過 `params` 屬性指定。

### 4. 確定處理方法和攔截器

一旦找到匹配的處理器,`HandlerMapping` 返回一個 `HandlerExecutionChain`,包含處理方法和相關的攔截器(`HandlerInterceptor`)。

### 5. 調用處理器適配器 (`HandlerAdapter`)

`DispatcherServlet` 根據處理方法的類型,選擇合適的 `HandlerAdapter` 執行處理方法。常見的適配器有:

- **`RequestMappingHandlerAdapter`**:處理 `@RequestMapping` 注解的方法。

- **`SimpleControllerHandlerAdapter`**:處理實現 `Controller` 接口的類。

### 6. 執行處理方法

`HandlerAdapter` 調用處理方法,并處理參數解析和返回值處理:

- **參數解析**:使用 `HandlerMethodArgumentResolver` 解析請求參數,支持多種參數類型,如請求體 (`@RequestBody`)、路徑變量 (`@PathVariable`)、請求頭 (`@RequestHeader`) 等。

- **返回值處理**:使用 `HandlerMethodReturnValueHandler` 處理返回值,支持視圖解析、JSON 序列化等。

### 7. 返回結果

處理方法執行后,返回 `ModelAndView` 對象或直接返回數據。`DispatcherServlet` 根據返回值進行視圖渲染或直接響應數據給客戶端。

### 總結

Spring Boot 的請求映射原理通過 `DispatcherServlet`、`HandlerMapping`、`HandlerAdapter` 等組件協同工作,實現了請求路徑與處理方法的映射,以及請求參數和返回值的處理。開發者可以通過 `@RequestMapping` 等注解靈活配置請求映射規則,構建 RESTful API 和 Web 應用。

---

通過以上步驟,Spring Boot 完成了從接收請求到返回響應的整個流程,實現了高效、靈活的請求處理機制。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/81689.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/81689.shtml
英文地址,請注明出處:http://en.pswp.cn/web/81689.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java設計模式之解釋器模式詳解

Java設計模式之解釋器模式詳解 一、解釋器模式核心思想 核心目標:定義語言的文法規則,并構建解釋器來解釋語言中的句子。如同編譯器將源代碼轉換為可執行代碼,解釋器模式將領域特定語言(DSL)的表達式解釋為可執行操作…

electron開發百度桌面應用demo及如何打包應用

1.開發入口文件main.js 1-1 加載百度URL const { app, BrowserWindow, nativeImage } require(electron) const path require(node:path)const createWindow () > {const win new BrowserWindow({width: 800,height: 600,})//加載百度URLwin.loadURL(https://www.baid…

LiveGBS海康、大華、宇視、華為攝像頭GB28181國標語音對講及語音喊話:攝像頭設備與服務HTTPS準備

LiveGBS海康、大華、宇視、華為攝像頭GB28181國標語音對講及語音喊話:攝像頭設備與服務HTTPS準備 1、背景2、準備工作2.1、服務端必備條件(注意事項)2.2、語音對講設備準備2.2.1、大華攝像機2.2.2、海康攝像機 3、開啟音頻并開始對講4、相關問…

JWT安全:假密鑰.【簽名隨便寫實現越權繞過.】

JWT安全:假密鑰【簽名隨便寫實現越權繞過.】 JSON Web 令牌 (JWT)是一種在系統之間發送加密簽名 JSON 數據的標準化格式。理論上,它們可以包含任何類型的數據,但最常用于在身份驗證、會話處理和訪問控制機制中發送有關用戶的信息(“聲明”)。…

# Python 語音助手本地的ollama實現

項目簡介 本項目是一個基于 Python 的智能語音助手,集成了語音錄制、語音識別、AI對話和語音合成功能。用戶可以通過語音與本地部署的 Ollama 大模型進行自然對話。 技術架構 核心功能模塊 語音錄制 - 使用 sounddevice 錄制用戶語音語音識別 - 使用 faster-whi…

第1章第1節:安全運維基礎思維與體系建設-安全運維的定義與核心目標

🎯 實戰目標: 理解“安全運維”與傳統運維的本質區別 掌握安全運維的核心目標與價值定位 建立以“持續可控、可視可審、自動響應”為核心的思維框架 📖 背景知識: ? 傳統運維 vs 安全運維 傳統運維關注:系統穩定、…

LNMP 架構部署

目錄 一、基于授權的訪問控制 (一)功能簡介 (二)配置步驟 二、基于客戶端的訪問控制 (一)功能簡介 (二)配置步驟 三、Nginx 虛擬主機 (一)基于域名的…

JVM與JMM深度解析:從Java 8到Java 21的演進

文章目錄 第一部分:JVM基礎概念與架構JVM是什么?JVM整體架構運行時數據區類加載機制執行引擎 第二部分:Java內存模型(JMM)什么是Java內存模型JMM的核心問題主內存與工作內存內存間交互操作重排序與happens-before原則v…

Docker 掛載卷并保存為容器

1 創建docker容器 使用鏡像osrf/ros:humble-desktop-full-jammy創建并運行容器 sudo docker run -it --name ros2_humble osrf/ros:humble-desktop-full-jammy /ros_entrypoint.sh bash docker run -it -v d:\docker\ros2_humble:/root/ros2_ws osrf/ros:humble-desktop-fu…

無人機飛手共享接單平臺

2025年,無人機已不再是“黑科技”的代名詞。從農田噴灑到外賣配送,從航拍攝影到醫療急救,無人機正以驚人的速度滲透我們的生活。而在這場變革中, “無人機飛手共享接單平臺” 成為連接技術與需求的核心樞紐。它不僅讓專業飛手輕松…

【Web應用】若依框架:基礎篇07功能詳解-定時任務

文章目錄 ?前言?一、講解過程?二、動手實操?總結 標題詳情作者JosieBook頭銜CSDN博客專家資格、阿里云社區專家博主、軟件設計工程師博客內容開源、框架、軟件工程、全棧(,NET/Java/Python/C)、數據庫、操作系統、大數據、人工智能、工控、網絡、程序…

8.8 Primary ODSA service without ODSA Portal

主要ODSA服務(不使用ODSA門戶) 以下場景描述如下情況: ? 主ODSA客戶端應用程序被允許用于該類型的主設備,且對終端用戶啟用(已授權)。 ? 服務提供商(SP)能夠在不涉及ODSA門戶Web服…

深度檢測與動態透明度控制 - 基于Babylon.js的遮擋檢測實現解析

首先貼出實現代碼: OcclusionFader.ts import { AbstractEngine, Material, type Behavior, type Mesh, type PBRMetallicRoughnessMaterial, type Scene } from "babylonjs/core"; import { OcclusionTester } from "../../OcclusionTester"…

openssl 使用生成key pem

好的,以下是完整的步驟,幫助你在 Windows 系統中使用 OpenSSL 生成私鑰(key)和 PEM 文件。假設你的 openssl.cnf 配置文件位于桌面。 步驟 1:打開命令提示符 按 Win R 鍵,打開“運行”對話框。輸入 cmd&…

音視頻之視頻壓縮及數字視頻基礎概念

系列文章: 1、音視頻之視頻壓縮技術及數字視頻綜述 一、視頻壓縮編碼技術綜述: 1、信息化與視頻通信: 什么是信息: 眾所周知,人類社會的三大支柱是物質、能量和信息。具體而言,農業現代化的支柱是物質&…

傳統數據表設計與Prompt驅動設計的范式對比:以NBA投籃數據表為例

引言:數據表設計方法的演進 在數據庫設計領域,傳統的數據表設計方法與新興的Prompt驅動設計方法代表了兩種截然不同的思維方式。本文將以NBA賽季投籃數據表(shots)的設計為例,深入探討這兩種方法的差異、優劣及適用場景。隨著AI技術在數據領…

XCTF-web-mfw

發現了git 使用GitHack下載一下源文件&#xff0c;找到了php源代碼 <?phpif (isset($_GET[page])) {$page $_GET[page]; } else {$page "home"; }$file "templates/" . $page . ".php";// I heard .. is dangerous! assert("strpos…

Prompt Tuning與自然語言微調對比解析

Prompt Tuning 與輸入提示詞自然語言微調的區別和聯系 一、核心定義與區別 維度Prompt Tuning(提示微調)輸入提示詞自然語言微調本質優化連續向量空間中的提示嵌入(不可直接閱讀)優化離散自然語言文本(人類可理解)操作對象模型輸入嵌入層的連續向量(如WordEmbedding)自…

LVS的DR模式部署

目錄 一、引言&#xff1a;高并發場景下的流量調度方案 二、LVS-DR 集群核心原理與架構設計 &#xff08;一&#xff09;工作原理與數據流向 數據包流向步驟3&#xff1a; &#xff08;二&#xff09;模式特性與53網絡要求 三、實戰配置&#xff1a;從9環境搭建到參數調整…

8種常見數據結構及其特點簡介

一、8種常見數據結構 1. 數組&#xff08;Array&#xff09; 簡介&#xff1a;數組是有序元素的序列&#xff0c;連續內存塊存儲相同類型元素&#xff0c;通過下標直接訪問。數組會為存儲的元素都分配一個下標&#xff08;索引&#xff09;&#xff0c;此下標是一個自增連續的…