Spring-web 解析

spring-web 是 Spring 框架的核心模块之一,主要负责处理 Web 应用开发中的通用基础设施。它不依赖于 Spring MVC,提供了很多底层但关键的功能。

以下是它的核心功能解析:

1. 核心特性与组件

  • HTTP 消息转换器
    HttpMessageConverter 接口是核心,负责将 HTTP 请求体转换为 Java 对象,以及将 Java 对象转换为 HTTP 响应体。

    内置实现包括处理 JSON(Jackson)、XML(JAXB)、表单数据、字节流、字符串等。

  • RestTemplate 同步客户端

    传统的同步 HTTP 客户端,提供模板方法(getForObjectpostForEntity 等)简化 HTTP 请求。虽然 Spring 5 新增了响应式 WebClient,但许多旧项目仍在广泛使用。

  • 异步非阻塞支持

    提供了 CallableDeferredResult 及与 CompletableFuture 的集成,允许在 Servlet 容器中异步处理请求,提高线程利用率。

  • WebUtils 与工具类

    例如 ServletRequestUtils 用于解析请求参数、CookieGenerator 管理 Cookie、HtmlUtils 转义 HTML 等实用工具。

  • HTTP 请求/响应包装器

    ContentCachingRequestWrapper,可以在拦截器中多次读取请求体(原生 Servlet 请求体只能读一次)。

  • Spring Web 注解

    包括 @RequestPart(文件上传)、@RequestParam@RequestHeader@CookieValue 等,用于数据绑定。

    (注意:@Controller@RequestMapping 虽然常用,但实际定义在 spring-webmvcspring-webflux 中)

2. 模块定位与区别

模块 作用
spring-web 基础 Web 功能,不依赖 Servlet 3.0+ 容器;提供通用 HTTP 客户端、消息转换、异步支持等。
spring-webmvc 基于 Servlet API 的 MVC 框架(通常说的 Spring MVC),依赖 spring-web
spring-webflux 响应式 Web 框架,基于 Reactor Netty 或 Servlet 3.1+,同样依赖 spring-web

3. 典型应用场景

  • 编写 HTTP 客户端 (如调用外部 REST API)时使用 RestTemplate

  • 开发 非 MVC 的 Web 组件 ,比如自定义 FilterServlet 时借助消息转换器处理 JSON。

  • 构建 异步请求处理 的底层支持。

  • Spring MVC 或 WebFlux 中作为底层支撑,提供通用的 HTTP 抽象。

4. 版本演变注意

  • Spring 5 :全面支持响应式,引入 WebClient 推荐替代 RestTemplate(不过 RestTemplate 在 Spring 5 中仍可用,被标记为维护模式)。

  • Spring 6 :需要 Jakarta EE 9+javax.servletjakarta.servlet),同时 RestTemplate 仍在,但官方更推荐 WebClient 或 HTTP Interface 客户端。

5. 简单代码示例

消息转换示例:手动使用 JSON 转换器

java 复制代码
MappingJackson2HttpMessageConverter converter = new MappingJackson2HttpMessageConverter();
MyObject obj = new MyObject("test");
HttpOutputMessage msg = new MockHttpOutputMessage();
converter.write(obj, MediaType.APPLICATION_JSON, msg);
// msg.getBody() 得到 JSON 字符串

RestTemplate 用法(同步 GET 请求)

java 复制代码
RestTemplate rest = new RestTemplate();
String result = rest.getForObject("https://api.example.com/data", String.class);
// 自动根据响应 Content-Type 选择消息转换器

异步请求处理(结合 DeferredResult)

java 复制代码
@GetMapping("/async")
public DeferredResult<String> async() {
    DeferredResult<String> dr = new DeferredResult<>();
    CompletableFuture.supplyAsync(() -> "done").thenAccept(dr::setResult);
    return dr;
}
// 此方法立即返回,释放容器线程,待异步完成后再响应

总结来说,spring-web 是 Spring Web 技术栈的 底层抽象层 ,提供了 HTTP 交互的通用组件,无论是同步还是响应式编程模型都依赖它。如果需要开发 Web 应用(带页面或 REST API),通常需要再组合 spring-webmvcspring-webflux

相关推荐
竹林8184 小时前
监听智能合约事件,我用 wagmi v2 踩了三天坑,终于找到了稳定方案
前端·javascript
星栈4 小时前
Makepad 界面怎么做得更像产品,而不是示例
前端·rust
Momo__4 小时前
SSR 懒水合四件套 — 99%的人不知道 Vue 3.5 藏了这些水合策略
前端·vue.js·性能优化
摇滚侠4 小时前
Spring 零基础入门到进阶 入门 06-10
java·spring·intellij-idea
riuphan4 小时前
JavaScript 事件循环:单线程异步编程的核心机制
前端·javascript
要开心吖ZSH4 小时前
AI医疗分诊与健康咨询助手agent开发——(1)从零搭建SpringBoot与AI对话系统:后端骨架 + 前端对话页 + SSE流式输出
java·ai·agent·健康医疗
biubiubiu07064 小时前
SpringBoot生产级日志配置
java·spring boot·后端
YHHLAI4 小时前
告别传统开发!Bun + TS 解锁前端新体验
前端
ch.ju4 小时前
Java Programming Chapter 4——Inherited call
java·开发语言
是有头发的程序猿4 小时前
竞品分析 + 用户洞察自动化|基于 item_review 评论接口 + 多 AI Agent 实现淘宝评论全量采集与智能分析(附python源码)
java·python·自动化