当前位置: 首页 > ops >正文

Postman 四种请求体格式全解析:区别、用法及 Spring Boot 接收指南

Postman 四种请求体格式全解析:区别、用法及 Spring Boot 接收指南

在接口开发中,请求体格式的选择直接影响数据传输的效率和正确性。Postman 作为主流的接口调试工具,提供了 Form Data、x-www-form-urlencoded、Raw、Binary 四种常用请求体格式。本文将详细解析这四种格式的区别,重点对比 Form Data 与 x-www-form-urlencoded,并结合 Spring Boot 示例说明如何正确接收参数。

一、四种请求体格式的核心区别

Postman 的 Body 选项中,四种格式的设计初衷和适用场景差异显著,具体如下:

1. Form Data(multipart/form-data)

  • 本质:通过“分隔符(boundary)”分割多个键值对的复合格式,支持文本和二进制数据(如文件)。
  • 核心特点
    • 每个字段独立成块,包含字段名、内容类型(如文本/文件)等元信息。
    • 非 ASCII 字符(如中文、特殊符号)无需手动编码,直接传输原始字节。
    • 支持同时传递文本和文件(例如:上传用户头像时,同时传递用户 ID 和昵称)。
  • 请求体示例(简化版):
    --Boundary123456  // 分隔符(自动生成)
    Content-Disposition: form-data; name="username"  // 文本字段名张三  // 字段值(中文无需编码)
    --Boundary123456
    Content-Disposition: form-data; name="avatar"; filename="head.jpg"  // 文件字段
    Content-Type: image/jpeg  // 文件类型[二进制文件内容]  // 直接传输文件字节
    --Boundary123456--  // 结束符
    

2. x-www-form-urlencoded

  • 本质:将键值对拼接为字符串(如 key1=value1&key2=value2),并对非 ASCII 字符进行 URL 编码。
  • 核心特点
    • 仅支持文本数据,不支持文件传输(因编码后为纯文本,无法承载二进制)。
    • 数据体积小,编码后为单一字符串,适合简单表单提交(如登录、搜索框查询)。
  • 请求体示例
    username=%E5%BC%A0%E4%B8%89&age=20  // "张三"被URL编码为%E5%BC%A0%E4%B8%89
    

3. Raw

  • 本质:纯文本格式,支持 JSON、XML、HTML 等结构化数据,需手动指定 Content-Type
  • 核心特点
    • 适合传递复杂结构化数据(如 API 接口的 JSON 请求体)。
    • Postman 会根据选择的格式自动设置 Content-Type(例如:选 JSON 则自动添加 application/json 头)。
  • 常见场景:后端接口要求接收 JSON 格式的用户信息(如 {"name":"张三","age":20})。

4. Binary

  • 本质:二进制数据流,对应 Content-Type: application/octet-stream
  • 核心特点
    • 仅支持单个二进制文件(如上传压缩包、图片),无键值对概念。
    • 直接传输文件原始字节,适合纯文件上传场景(如“上传附件”功能)。

二、重点:Form Data 与 x-www-form-urlencoded 的核心区别

虽然两者都以键值对形式传输数据,但在编码方式、支持类型、适用场景上有本质区别,具体对比如下:

对比维度Form Data(multipart/form-data)x-www-form-urlencoded
编码方式用分隔符分割多个字段,每个字段独立成块所有字段拼接为单一字符串,URL编码
支持数据类型文本 + 二进制文件(如图片、文档)仅支持文本(无法传输文件)
非ASCII字符处理直接传输原始字节(无需编码)强制URL编码(如中文→%E5%BC%A0…)
数据体积较大(含分隔符和元信息)较小(纯字符串)
适用场景上传文件、混合文本与二进制数据简单表单提交(登录、搜索、参数提交)
Spring Boot接收差异支持 MultipartFile 接收文件仅支持文本参数,无法接收文件

一句话总结:如果需要传文件,必须用 Form Data;如果只是简单文本提交,x-www-form-urlencoded 更轻量。

三、Postman 中如何设置四种格式

1. Form Data 设置

  • 步骤:Body → 选择 form-data → 点击“+”添加键值对。
    • 文本参数:默认选“Text”,直接输入键和值(如 username: 张三)。
    • 文件参数:选择“File”,点击“Select Files”上传文件(如 avatar: head.jpg)。
  • 注意:Postman 会自动添加 Content-Type: multipart/form-data 及分隔符,无需手动设置。

2. x-www-form-urlencoded 设置

  • 步骤:Body → 选择 x-www-form-urlencoded → 直接添加键值对(如 name: 张三age: 20)。
  • 注意:Postman 会自动对非 ASCII 字符编码(如“张三”→%E5%BC%A0%E4%B8%89),并设置 Content-Type: application/x-www-form-urlencoded

3. Raw 设置

  • 步骤:Body → 选择 raw → 右侧下拉框选格式(如 JSON)→ 输入对应格式内容(如 {"name":"张三","age":20})。
  • 注意:格式需与内容匹配(如选 JSON 就必须输入合法 JSON 字符串)。

4. Binary 设置

  • 步骤:Body → 选择 binary → 点击“Select File”选择单个二进制文件(如 test.zip)。
  • 注意:一次只能传一个文件,无键名,仅传输文件字节流。

四、Spring Boot 中如何接收四种格式的参数

1. 接收 Form Data(multipart/form-data)

适用于文本+文件混合传输,用 @RequestParam 接收文本,MultipartFile 接收文件。

@RestController
public class FormDataController {// 接收文本+文件@PostMapping("/upload")public String handleFormData(@RequestParam("username") String username,  // 文本参数@RequestParam("avatar") MultipartFile avatar  // 文件参数) {String filename = avatar.getOriginalFilename(); // 获取文件名long fileSize = avatar.getSize(); // 获取文件大小return "收到用户:" + username + ",上传文件:" + filename + "(大小:" + fileSize + "字节)";}
}

2. 接收 x-www-form-urlencoded

适用于纯文本键值对,直接用 @RequestParam 接收(与 Form Data 的文本参数接收方式一致)。

@RestController
public class UrlEncodedController {@PostMapping("/submit")public String handleUrlEncoded(@RequestParam("name") String name,  // 接收文本参数@RequestParam("age") Integer age    // 自动转换类型) {return "收到用户:" + name + ",年龄:" + age;}
}

3. 接收 Raw

适用于结构化数据(如 JSON、XML),用 @RequestBody 绑定到对象或字符串。

// 定义接收JSON的实体类
public class User {private String name;private Integer age;// 必须提供getter和setter(Spring通过反射赋值)public String getName() { return name; }public void setName(String name) { this.name = name; }public Integer getAge() { return age; }public void setAge(Integer age) { this.age = age; }
}@RestController
public class RawController {// 接收JSON并自动绑定到User对象@PostMapping("/user")public String handleJson(@RequestBody User user) {return "用户信息:姓名=" + user.getName() + ",年龄=" + user.getAge();}// 直接接收原始XML文本@PostMapping("/xml")public String handleXml(@RequestBody String xml) {return "收到XML内容:" + xml;}
}

4. 接收 Binary

适用于单个二进制文件,用 MultipartFile 接收(与 Form Data 的文件接收方式相同)。

@RestController
public class BinaryController {@PostMapping("/upload-file")public String handleBinary(@RequestParam("file") MultipartFile file) {return "收到二进制文件:" + file.getOriginalFilename() + ",类型:" + file.getContentType();}
}

五、总结

请求体格式适用场景核心特点Spring Boot 接收方式
Form Data文本+文件混合传输支持二进制,分隔符分隔@RequestParam(文本)+ MultipartFile(文件)
x-www-form-urlencoded纯文本表单提交URL编码,仅支持文本@RequestParam
Raw结构化数据(JSON/XML等)纯文本,需指定格式@RequestBody(绑定对象或字符串)
Binary单个二进制文件无键值对,原始字节流MultipartFile

掌握这四种格式的差异,尤其是 Form Data 与 x-www-form-urlencoded 的区别,能帮助我们在前后端联调中快速选择合适的传输方式,避免“传文件失败”“参数乱码”等常见问题。

http://www.xdnf.cn/news/16957.html

相关文章:

  • 手搓TCP服务器实现基础IO
  • 华为2288H V5服务器闪红灯 无法开机案例
  • 8.4IO进程线程——进程
  • 1.2 医学影像处理基本概念
  • 【OpenAI API】API接口介绍
  • Mac桌面仿制项目--让ai一句话生成的
  • ROS2机器人编程新书推荐-2025-精通ROS 2机器人编程:使用ROS 2进行复杂机器人的设计、构建、仿真与原型开发(第四版)
  • kraft的设计与实现
  • Matlab 高斯牛顿法拟合曲线
  • 机器学习——决策树(DecisionTree)
  • Flutter Dart类的使用
  • Petalinux 23.2 构建过程中常见下载错误及解决方法总结
  • k8s+isulad 国产化技术栈云原生技术栈搭建3-master节点安装
  • 音视频学习(四十九):音频有损压缩
  • TVS二极管数据手册解读
  • Android系统模块编译调试与Ninja使用指南
  • Spring AOP_2
  • 【大模型篇】:GPT-Llama-Qwen-Deepseek
  • Linux进程启动后,监听端口几分钟后消失之问题分析
  • 【游戏比赛demo灵感】Scenario No.9(又名:World Agent)
  • 基于pytorch深度学习笔记:3.GooLeNet介绍
  • RT-Thread **标准版(Standard)** 和 **智能版(Smart)
  • LLM - AI大模型应用集成协议三件套 MCP、A2A与AG-UI
  • Rust 同步方式访问 REST API 的完整指南
  • 04.Redis 的多实例
  • Linux 文件系统基本管理
  • go 中的 fmt 占位符
  • 【lucene】ByteBufferGuard
  • RabbitMQ面试精讲 Day 9:优先级队列与惰性队列
  • 深度学习中的三种Embedding技术详解