测试接口传参数时,放在Header和Body中后台接收参数的区别

Post 请求:参数放 Header / Body 后端接收区别(SpringBoot)

一、参数放在 Header(请求头)

1、取值注解:@RequestHeader

java 复制代码
@PostMapping("/header")
public String getHeader(@RequestHeader("token") String token) {
    return token;
}
  • 位置:Postman → Headers 面板填 key=value
  • 特点
  1. 不属于请求体,和 GET/POST 无关,GET 也能在 Header 带参
  2. 无法传复杂对象、数组,只适合短字符串(token、appId、版本号)
  3. 不会被@RequestBody读取,和 Body 参数互不干扰
  4. 参数不在 url、不在 body,抓包在请求头字段

二、参数放在 Body(请求体)分两种格式

① Body → x-www-form-urlencoded(表单格式)

取值:@RequestParam

java 复制代码
@PostMapping("/form")
public String getForm(@RequestParam("name") String name) {
    return name;
}
  • Postman:Body→x-www-form-urlencoded,键值对
  • 底层:表单拼接name=xx&age=18,放到请求体
  • 不能用 @RequestBody 接收

② Body → raw-JSON(最常用)

取值:@RequestBody整个 body 封装成对象

java 复制代码
@PostMapping("/json")
public String getJson(@RequestBody User user) {
    return user.getName();
}
  • Postman:Body→raw→JSON {"name":"张三"}
  • 规则:
  1. @RequestBody一次性读取整个 Body 流,一个接口只能出现一次
  2. 不能搭配@RequestParam拿 body 里字段
  3. 支持对象、数组、嵌套复杂结构

三、核心对比汇总

位置 取值注解 数据格式 适用场景
Header @RequestHeader 单个字符串 token、鉴权、设备信息
Body 表单 @RequestParam key=val&key=val 简单键值、老表单提交
Body JSON @RequestBody JSON{}/\[\] 前后端分离、复杂入参

四、高频踩坑

  1. JSON 参数放 Body,却用 @RequestParam:拿不到值,报参数缺失
  2. Header 参数用 @RequestBody:拿不到,RequestBody 只读 body
  3. 一个接口:@RequestHeader(头) + @RequestBody(体) 可以共存,互不冲突
相关推荐
冬奇Lab1 小时前
每日一个开源项目(第143篇):page-agent - 纯 JS 的网页 GUI Agent,无需截图、无需插件、无需后端
前端·人工智能·agent
IT_陈寒6 小时前
React的这个渲染问题连官方文档都没说清楚
前端·人工智能·后端
狼爷7 小时前
吃透 Java Function 接口,搞定 99% 的 Stream 场景
java·函数式编程
追逐时光者7 小时前
别再满网找零散工具了,腾讯 QQ 浏览器这个“帮小忙”工具箱真能省时间
前端·后端
Asmewill9 小时前
grep&curl命令学习笔记
前端
stringwu9 小时前
Flutter 开发必备:MVI 架构的高效实现指南
前端·flutter
用户21366100357210 小时前
Vue2组件化开发与父子通信
前端·vue.js
祎雪双十Gy11 小时前
从 DataX 的配置加载说起:我用 FastJson2 做了一个轻量级动态配置管理库
java·后端
Momo__11 小时前
TypeScript satisfies 操作符——比 as 更安全的类型守门员
前端·typescript
用户21366100357211 小时前
Vue2事件系统与指令进阶
前端·vue.js