无论是前端,还是后端开发,HTTP 接口的使用率实在是太高了。开发好了特定的 HTTP 接口,没有一个好的测试工具,怎么可以呢?

而 Postman 就是一款好用的爱不释手的测试工具,谁用谁说爽。

接口说明

已开发好 /woms/api/UpEvent.php 的 HTTP 接口。该接口完成 JSON 消息上报及若干图片文件上传的任务。主要通过 HTTP 的 multipart/form-data 格式推送数据到服务器。该格式详细定义可见  RFC1867

Postman 登场

Postman 是 Chrome 的插件,但我觉得 PC 版更好,我选择 PC 版本!Postman-win64-7.7.3-Setup.exe

安装好之后,初次打开,需要注册账号,按照提示,输入账号,设置密码,然后就可以注册成功。登录进入主界面后。第一眼,就看着特别舒服。

Postman 调试 HTTP 接口

主要有3点:

  • 输入测试接口

    点击 Create a request, 输入 http 测试接口

  • 按照接口方法构造测试数据

    根据 Multipart/form-data 有几部分内容,就输入 几个键名称 和 值内容, 截图见下!

  • 查看输出,验证结果

    Postman 调试截图如下:

注意:上图我用红色小圈括起来的部分,这里一定不可以选错。

抓包截图如下:

抓包看: 共发送了6段数据,第一段是 Json,其余的都是 jpeg 的图片。其实这里的第一段 Json 数据就是对5张图片数据的描述。

HTTP multipart/form-data 补充

multipart/form-data 主要是将多条表单的数据处理为一条消息,发送到服务器。

多条消息之间用分隔符分开。分隔符用 boundary=xxxxxx 来定义,xxxxx就是分隔符。

这样一个 HTTP 请求,由于有 boundary 隔离,既可以上传文本消息的同时,也可以上传文件。当上传的字段是文件时,可用 Content-Type 标明文件类型;

消息实例的具体文本如下:其中图片数据特别多(乱码部分),我特意删除后贴出来:

 POST /woms/api/UpEvent.php HTTP/1.1
Content-Type: multipart/form-data; boundary=----
User-Agent: PostmanRuntime/7.17.
Accept: */*
Cache-Control: no-cache
Postman-Token: 552bb4b0-ddbe-4e10-b5b1-dd16ce6afe82
Host: 192.168.100.146
Accept-Encoding: gzip, deflate
Content-Length: 661588
Connection: keep-alive ----4235013262151947840
Content-Disposition: form-data; name="info"
Content-Type: application/json {"AuthUser":"13800001111",
"AuthPasswd ":"123456",
"Timestamp":"1568743234",
"EventTime":"1568743234",
"EventType":1,
"EventLevel":2,
"EventSubject":"Test",
"EventDesc":"Test",
"Longitude":"33.44",
"Latitude": "116.43",
"AccpetUser": "18200129832",
"FileList": [{
"FileName": "haha.jpg",
"FileSize": 83},
{"FileName": "haha.txt",
" FileSize": 16}]
}
----4235013262151947840
Content-Disposition: form-data; name="file1"; filename="haha.jpg"
Content-Type: image/jpeg ???àJFIF??C
$.' ",#(7),01444'9=82<.342??C
----4235013262151947840
Content-Disposition: form-data; name="file2"; filename="6.jpeg"
Content-Type: image/jpeg ???á
ExifII*4M¤?(1"′2?iì$ü
?áT?a1??ù
----4235013262151947840
Content-Disposition: form-data; name="file3"; filename="7.jpeg"
Content-Type: image/jpeg ?s??:?ó?μ???üo6??é_?o????~áczóê??A????&???#áè?????áè??ù
----4235013262151947840
Content-Disposition: form-data; name="file4"; filename="8.jpeg"
Content-Type: image/jpeg ?y??ü·á??ù
----4235013262151947840
Content-Disposition: form-data; name="file5"; filename="9.jpeg"
Content-Type: image/jpeg ???á7%ExifMM*44¤?(1"′2?iì$
?}?.W§?N/éy}'ü?%ì}′ù=±ú??S?g???Yoíùüê|t???ú??ù
----4235013262151947840--

Postman 之 HTTP Multipart/form-data 调试的更多相关文章

  1. html5 file upload and form data by ajax

    html5 file upload and form data by ajax 最近接了一个小活,在短时间内实现一个活动报名页面,其中遇到了文件上传. 我预期的效果是一次ajax post请求,然后在 ...

  2. Sending forms through JavaScript[form提交 form data]

    https://developer.mozilla.org/en-US/docs/Learn/HTML/Forms/Sending_forms_through_JavaScript As in the ...

  3. 【转】HTTP请求中的form data和request payload的区别

    jQuery的ajax方法和post方法分别发送请求,在后台Servlet进行处理时结果是不一样的,比如用$.ajax方法发送请求时(data参数是一个JSON.stringify()处理后的字符串, ...

  4. [转]HTTP请求中的form data和request payload的区别

    本文转自:http://www.cnblogs.com/btgyoyo/p/6141480.html jQuery的ajax方法和post方法分别发送请求,在后台Servlet进行处理时结果是不一样的 ...

  5. form data和request payload的区别

    HTML <form> 标签的 enctype 属性 在下面的例子中,表单数据会在未编码的情况下进行发送: <form action="form_action.asp&qu ...

  6. Web 前沿——HTML5 Form Data 对象的使用

    XMLHttpRequest Level 2 添加了一个新的接口——FormData.利用 FormData 对象,我们可以通过 JavaScript 用一些键值对来模拟一系列表单控件,我们还可以使用 ...

  7. HTTP请求中的form data和request payload的区别

    HTML <form> 标签的 enctype 属性 在下面的例子中,表单数据会在未编码的情况下进行发送: <form action="form_action.asp&qu ...

  8. [整理]Ajax Post请求下的Form Data和Request Payload

    Ajax Post请求下的Form Data和Request Payload 通常情况下,我们通过Post提交表单,以键值对的形式存储在请求体中.此时的reqeuest headers会有Conten ...

  9. AJAX POST请求中参数以form data和request payload形式在servlet中的获取方式

    转载:http://blog.csdn.net/mhmyqn/article/details/25561535 HTTP请求中,如果是get请求,那么表单参数以name=value&name1 ...

  10. Sending HTML Form Data

    public Task<HttpResponseMessage> PostFormData(){ // Check if the request contains multipart/fo ...

随机推荐

  1. HandlerMethodArgumentResolver(一):Controller方法入参自动封装器【享学Spring MVC】

    每篇一句 你的工作效率高,老板会认为你强度不够.你代码bug多,各种生产环境救火,老板会觉得你是团队的核心成员. 前言 在享受Spring MVC带给你便捷的时候,你是否曾经这样疑问过:Control ...

  2. odoo项目结构参数属性详解

    1.基础文件及目录结构 在认识odoo ORM框架前,先介绍一下odoo中模块目录结构.   data:存放模块预制数据i18n:存放国际化文件models:存放模型等py代码security:存放权 ...

  3. ECMAScript---object对象类型详解

    普通对象:由大括号包裹起来的,由零到多个属性名和属性值(键值对)组成的 那什么是属性呢? 属性:描述当前对象特征的,属性名是当前具备这个特征,属性值是这个特征的描述(专业语法,属性名称为键[key], ...

  4. Zabbix安装时出现缺少PHP模块,解决过程

    我在安装时PHP缺少gettext模块和bcmath模块:一下为解决步骤: 1.进入到PHP源码包目录下的ext目录: #cd /soft/php-/ext 2.会看到ext目录下有gettext目录 ...

  5. Codeforces 1204C

    题意略. 思路:我的想法是逐步地找出这个序列中的重要点,我要判断当前这个点能不能删去,就要看上一个重要点和当前这个点 i 在序列中的下一个点 i + 1之间的距离 是否是最短距离,如果是,那么我们就可 ...

  6. Java开发必备技能

    --------转载自B站up主 codeSheep 基础知识 编程语言:Java Python C 基本算法 基本网络知识:TCP/IP  HTTP/HTTPS 基本的设计模式 工具方面 操作系统: ...

  7. Codeforces Round #364 (Div. 2) D. As Fast As Possible 数学二分

    D. As Fast As Possible 参考:https://blog.csdn.net/keyboardmagician/article/details/52769493 题意: 一群大佬要走 ...

  8. 洛谷P1240-诸侯安置+递推非搜索

    诸侯安置 这道题是一题递推题,一开始自己不知道,用了搜索,只过了三个样例: 两两相同的合并, 成 1,1,3,3,5,5........n*2-1; 然后我们会容易发现一种不同与搜索的动态规划做法. ...

  9. CodeForces 474F Ant colony ST+二分

    Ant colony 题解: 因为一个数是合法数,那么询问区间内的其他数都要是这个数的倍数,也就是这个区间内的gcd刚好是这个数. 对于这个区间的gcd来说,不能通过前后缀来算. 所以通过ST表来询问 ...

  10. hdu 4725 The Shortest Path in Nya Graph(建图+优先队列dijstra)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4725 题意:有n个点和n层,m条边,每一层的任意一个点都可以花费固定的值到下一层或者上一层的任意点 然 ...