spring中 HTTP 请求常见格式

Spring MVC(或 Spring Boot)中,处理 HTTP 请求(如 POST、GET、DELETE、PUT 等)时,可以使用不同的注解来绑定请求中的数据到控制器方法的参数上。

java 复制代码
@RestController
@RequestMapping("/api/users")
public class UserController {

    // GET /api/users
    @GetMapping
    public List<User> getAllUsers() {
        // 返回所有用户
    }

    // GET /api/users/123
    @GetMapping("/{id}")
    public User getUserById(@PathVariable Long id) {
        // 根据 ID 查询
    }

    // POST /api/users
    @PostMapping
    public User createUser(@RequestBody User user) {
        // 保存新用户,返回带 ID 的对象
    }

    // PUT /api/users/123
    @PutMapping("/{id}")
    public User updateUser(@PathVariable Long id, @RequestBody User user) {
        // 全量更新用户
    }

    // PATCH /api/users/123
    @PatchMapping("/{id}")
    public User patchUser(@PathVariable Long id, @RequestBody Map<String, Object> updates) {
        // 部分更新(如只改 email)
    }

    // DELETE /api/users/123
    @DeleteMapping("/{id}")
    public ResponseEntity<Void> deleteUser(@PathVariable Long id) {
        // 删除用户
        return ResponseEntity.noContent().build(); // 204
    }

    // GET /api/users?username=alice
    @GetMapping(params = {"username"}) // 可选:限定必须带 username
    public List<User> searchByUsername(@RequestParam String username) {
        // 按用户名模糊查询
    }
}

方法参数不写注解默认是@RequestParam

特性 / 注解 @PathVariable @RequestParam @RequestBody
适用位置 方法参数 方法参数 方法参数
适用 HTTP 方法 所有(只要 URL 含路径变量) GET、POST、PUT、DELETE(任何带 query 或 form-data 的请求) POST、PUT、PATCH(通常不用于 GET/DELETE)
数据来源 URL 路径片段(如 /users/{id} URL 查询参数(?key=value)或表单字段(application/x-www-form-urlencodedmultipart/form-data HTTP 请求体(raw body),如 JSON、XML
支持基本类型 (如 String, Long, int ✅(但极少使用,易出错)
支持实体类(POJO) ✅(无需加注解,Spring 自动绑定) ✅(必须加注解,用于反序列化 JSON 等)
支持 Map<String, String> ✅(自动收集所有 query/form 参数) ✅(常用于接收结构未知的 JSON 对象,建议用 Map<String, Object> 更灵活)
多参数支持 每个路径变量需单独声明一个参数 ✅ 可多个 @RequestParam,或用 POJO / Map 一次性接收 ❌ 一个方法仅允许一个 @RequestBody
是否可省略注解 ❌ 必须显式标注 ⚠️ 基本类型可省略(默认视为 @RequestParam),但不推荐;POJO 不能加此注解 ❌ 必须显式标注,否则无法识别请求体
典型使用场景 RESTful 资源 ID:/users/123 搜索条件、分页、表单提交:?page=1&size=10 创建/更新资源:发送 JSON 对象 { "name": "Alice" }
相关推荐
学代码的真由酱5 分钟前
Java多用户一对一网页聊天室-测试报告
java·开发语言·功能测试·测试
Jasonakeke1 小时前
SpringBoot自动配置原理揭秘
java·spring boot·后端
2301_803538951 小时前
Java读取Word图片的两种实用方法
java·开发语言·word
C137的本贾尼1 小时前
Spring AI Alibaba 模型全家桶:接入通义、百川、LLaMA 等第三方 LLM
人工智能·spring·llama
C+-C资深大佬2 小时前
SSM 框架(Spring + SpringMVC + MyBatis)
java·spring·mybatis
帅次2 小时前
Android 17 开发者实战:核心更新与应用场景落地指南
android·java·ios·android studio·iphone·android jetpack·webview
Ramble_Naylor2 小时前
东方通(TongWeb)SpringBoot开发指导
java·spring boot
大鹏说大话2 小时前
SQL 排序与分组实战:解决“分组后取最新数据“
android·java·数据库
云烟成雨TD2 小时前
Spring AI Alibaba 1.x 系列【64】 ReactAgent 长期记忆
java·人工智能·spring
quan26312 小时前
20260529,日常开发-数据库主从问题
java·mysql·主从·延迟