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

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.lryc.cn/news/609633.html

相关文章:

  • 实习005 (web后端springboot)
  • 【后端】Java static 关键字详解
  • 从零开始搞定类与对象(中)
  • Matplotlib与PySide6兼容性问题及解决方案
  • open-webui pipelines报404, ‘Filter pipeline.exporter not found‘
  • 基于Express+Ejs实现带登录认证的多模块增删改查后台管理系统
  • C++ 浅谈Robin Hood Hash 算法
  • 3ds Max 渲染效率提升指南:从场景设计优化开始
  • 【0基础3ds Max】常用快捷键
  • 【Linux下Java应用自动重启守护教程】
  • 【大模型】3D因果卷积动图怎么画
  • Linux—yum仓库及NFS网络共享服务
  • [QMT量化交易小白入门]-七十六、从tick数据中获取高频交易的量价背离信号
  • 验证码等待时间技术在酒店自助入住、美容自助与社区场景中的应用必要性研究—仙盟创梦IDE
  • Dynamic Programming【DP】2
  • 9.感知机、神经网络
  • Antlr学习笔记 01、maven配置Antlr4插件案例Demo
  • 中标喜讯 | 安畅检测成功中标海南工信大脑(二期)软件测评服务
  • [Oracle] TO_NUMBER()函数
  • 【分享】拼团交易平台系统,分布式、高并发、微服务
  • 豆包1.6+PromptPilot实战:构建智能品牌评价情感分类系统的技术探索
  • Jetbrains IDE总是弹出“需要身份验证”窗口
  • uniapp 基础(三)
  • weapp-tailwindcss 已支持 uni-app x 多端构建
  • uniapp基础(四)性能优化
  • 使用opencv基于realsense D435i展示基本的图像
  • 计算机网络:有路由器参与的子网间通信原理
  • 阿里云与华为云产品的差异
  • 计算机网络:网络号和网络地址的区别
  • OpenCV轻松入门_面向python(第二章图像处理基础)