请求主体的内容:json
User-Agent: Fiddler
Content-Type: application/json
Host: localhost:5237
Content-Length: 133浏览器
参数:服务器
{
"Id": 123,
"Type": 3,
"Items": [{
"ItemId": 33,
"Count": 200
}]
}app
对于get请求来讲没有请求主体entity-body。对于post请求而言,不会对发送请求的数据格式进行限制,理论上你能够发任意数据,可是服务器能不能处理就是另外一回事了。服务器收到数据后,如何解析数据呢?post
它会以请求头中的Content-Type设置的内容来进行数据解析。肯定好Content-Type的格式以后,请求主体的数据格式也就肯定下来了。url
Content-Type的格式有四种:分别是application/x-www-form-urlencoded(这也是默认格式)、application/json、text/xml以及multipart/form-data格式。3d
接下来就详细地介绍每一种数据格式对应的fiddler请求模拟的实现状况。code
(一)application/x-www-form-urlencoded数据格式orm
这是post请求最多见也是默认的数据提交格式。它要求数据名称(name)和数据值(value)之间以等号相连,与另外一组name/value值之间用&相连。例如:parameter1=12345&meter2=23456。将请求的内容进行格式化了,其实这个方法同时简化的客户端发送,也简化了服务器端获取,服务器经过getParameters(String name)便可获取到传送来的信息。xml
用fiddler模拟请求的话,请求头和请求主体的内容能够这样构造:
模拟请求以后,从返回结果能够查看到咱们的请求数据:
(二)application/json数据格式
application/json格式的请求头是指用来告诉服务端post过去的消息主体是序列化后的 JSON 字符串。
用fiddler模拟请求的话,请求头和请求主体的内容能够这样构造:
模拟请求以后,从返回结果能够看到咱们的请求数据:
(三)text/xml数据格式
用fiddler模拟请求的话,请求头和请求主体的内容能够这样构造:
模拟请求以后,从返回结果能够看到咱们的请求数据:
(四)multipart/form-data数据格式
除了传统的application/x-www-form-urlencoded表单,咱们另外一个常常用到的是上传文件用的表单,这种表单的类型为multipart/form-data。
用fiddler模拟请求的话,请求头和请求主体的内容能够这样构造:
第一步,先设置好请求头格式,而后点击upload file...
第二步,上传你的文件,这里我上传一个png的图片
这是fiddler根据咱们上传的文件自动调整生成的请求,在请求头中看到,咱们须要选择一段数据做为“分割边界”(boundary属性),这个“边界数据”不能在内容其余地方出现,通常来讲使用一段从几率上说“几乎不可能”的数据便可。每次post浏览器都会生成一个随机的30-40位长度的随机字符串,浏览器通常不会遍历此次post的全部数据找到一个不可能出如今数据中的字符串,通常都是随机生成。选择了这个边界以后,浏览器便把它放在Content-Type 里面传递给服务器,服务器根据此边界解析数据。下面的数据便根据boundary划分段,每一段即是一项数据。(每一个field被分红小部分,并且包含一个value是"form-data"的"Content-Disposition"的头部;一个"name"属性对应field的ID等等,文件的话包括一个filename)
模拟请求以后,从返回结果能够看到咱们的请求数据:
界面截图以下:
使用很方便,只需设置如下节点:
一、设置请求的Headers,以下:
若是您接口返回的数据是Json类型,请使用第一种,若是您接口返回的数据是XML类型,请选择第二种,若是您返回结果是一个Pdf文件,请选择第三种......总之:根据本身的需求选择!
二、请将Body设置以下:
选中Raw选项,若是是Post请求,请在Body输入框中输入您要发送的Body请求体!以下:
三、请选择对应的请求方式:Get、Post、Put、Delete等,以下:
四、Post也支持相关的Jwt受权,Auth2.0受权等,我的没作太多研究!不做说明。通常的请求,不须要身份验证的,选择 No Auth 便可。