【转载】Post请求Body类型

本文详细介绍了Postman中四种请求体参数格式:form-data、x-www-form-urlencoded、raw和binary。form-data适用于文件上传,x-www-form-urlencoded用于常规表单数据,raw常用于发送JSON或XML数据,而binary则用于二进制数据如文件的传输。理解这些格式有助于更高效地进行API测试。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Postman的body的类型主要由四种类型的参数: form-data、x-www-form-urlencoded、raw、binary
图1
由于post请求的参数才放到请求体(Body)里面,get的请求参数一般都直接跟在url后面,所以这里Body里面参数都是指的post请求参数,那post请求测试时怎么判断选择哪个格式的来发送参数呢

一、form-data(multipart/form-data),支持上传文件的表单类型

form-data对应着http请求中的Content-Type=multipart/form-data, 一般在表单中如果需要进行文件上传时,就需要使用该格式。
它会将表单的数据处理为一条消息,以标签为单元,用分隔符分开。既可以上传键值对,也可以上传文件File。当上传的字段是文件时,会有Content-Type来说明文件类型;content-disposition用来说明一些字段信息;
由于有boundary隔离,所以multipart/form-data既可以上传文件,也可以上传键值对,它采用了键值对的方式,所以可以上传多个文件。
下图是fiddler抓包得到的某系统一个更新头像的接口,在这里我们可以看到Content-Type: multipart/form-data; boundary=---------------------------21317247322879,所以提交的参数文件是以分隔符---------------------------21317247322879来隔开的,以-----------------------------21317247322879-----来结束的
在这里插入图片描述
在这里插入图片描述
postman里面对该接口进行测试时参数Body里面选择的就是form-data格式
在这里插入图片描述
在这里插入图片描述

二、 x-www-form-urlencoded,表单类型的接口请求

对应着http请求中的Content-Type为application/x-www-from-urlencoded,会将表单内的数据转换为键值对,比如,name=python&age = 22,这种方式只能以键值对形式发送参数,一般如果不指定content-type,默认便是application/x-www-form-urlencoded。

如b站的注册接口采用的就是这种方式发送消息,如下图,通过抓包获取到Content-Type为application/x-www-from-urlencoded,参数数据就是以键值对的形式发送的
在这里插入图片描述
在这里插入图片描述

三、 raw(支持各种原生的类型的接口请求)

如:Content-Type=application/json时,则可以使用这种方式,这个是实际接口测试中,使用到最多的方式了。越来越多的人把它作为请求头,用来告诉服务端消息主体是序列化后的 JSON 字符串。

他是可以上传任意格式的参数,可以上传text、json、xml、html、js

在这里插入图片描述
在这里插入图片描述

四、 binary(二进制,流类型的接口请求 )

对应着http请求中的Content-Type:application/octet-stream,只可以上传二进制数据,通常用来上传文件,由于没有键值,所以,一次只能上传一个文件

### 解决 DeepSeek 请求错误问题 对于 DeepSeek 请求返回 400 状态码的情况,这通常意味着服务器无法理解客户端发送的请求,可能是由于语法有误或必要的信息缺失。为了有效处理此类错误并确保请求能够成功执行,可以采取以下几个方面来排查和解决问题。 #### 检查请求参数 当 API 返回 400 坏请求状态码时,表明存在不合法的请求参数[^1]。应仔细审查提交给服务端的数据结构及其内容: - 验证所有必需字段都已提供,并且格式正确。 - 对于字符串类型的参数,确认其长度未超出允许范围;数值类型则需满足指定区间内的取值要求。 - 如果涉及到文件上传或其他复杂对象,则要保证这些资源按照预期的方式进行了编码与传输。 ```json { "model_name": "example_model", "input_data": { "feature_1": value, "feature_2": another_value } } ``` #### 修改模型设置后重置默认配置 如果最近对模型做了更改,比如通过特定路径操作了 deepseek 中的相关选项[^2],那么可能是因为新设定导致了兼容性问题或是违反了一些预设条件而触发了错误响应。此时建议尝试恢复至原始出厂设置以排除潜在冲突因素的影响。 方式之一是在 Visual Studio Code 这样的集成开发环境中找到对应插件或者扩展包管理器中的 reset 功能按钮来进行全局性的初始化动作[^3]。不过请注意,在实际应用中应当谨慎对待任何涉及数据清除的操作前做好充分备份工作以免造成不必要的损失。 #### 参考 Cherry Studio API 文档 查阅官方提供的文档资料有助于更深入地了解各个接口的具体行为准则以及最佳实践指南。API 文档里会详细说明每种方法支持哪些 HTTP 方法(GET/POST)、URL 路径模式、可选查询参数列表还有可能出现的各种异常情况下的解决方案提示等重要知识点。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值