1

摘要

Postman 是一个接口测试和 http 请求的神器,非常好用。

官方 github 地址: github.com/postmanlabs

Postman 的优点:

  • 支持各种的请求类型: get、post、put、patch、delete 等

  • 支持在线存储数据,通过账号就可以进行迁移数据

  • 很方便的支持请求 header 和请求参数的设置

  • 支持不同的认证机制,包括 Basic Auth,Digest Auth,OAuth 1.0,OAuth 2.0 等

  • 响应数据是自动按照语法格式高亮的,包括 HTML,JSON 和 XML

2

安装

Postman 可以单独作为一个应用安装,也可以作为 chrome 的一个插件安装。

  • chrome 插件安装, Postman 插件地址(chrome.google.com/webstore/de…

  • 单独应用安装下载(files.cnblogs.com/files/mafly…

下面主要介绍下载安装独立版本app 软件的 Postman 的过程:

去主页Postman 官网(www.getpostman.com/)找到:Postman | Apps(www.getpostman.com/apps)

去下载自己平台的版本:

Mac Windows(x86/x64) Linux(x86/x64)

即可。

3

Postman的基础功能

4

快速入门

4.1 新建接口

对应的Request:New -> Request

Postman新建Request

或在右边的 Tab 页面中点击加号+:

Postman在Tab页新建Request

即可看到新建的 Tab 页:

Postman新建了的Tab页的Request

4.1.1 设置 HTTP 请求的方法

设置 HTTP 的 Method 方法和输入 api 的地址

Postman设置Method和输入API地址

4.1.2 设置相关请求头信息

Postman设置Header头的key

Postman设置Header头的value

4.1.3 设置相关 GET 或 POST 等的参数

Postman设置POST的Body的JSON

4.1.4 发送请求

都填写好之后,点击 Send 去发送请求 Request:

Postman点击发送请求

4.1.5 查看响应 Response的信息

Postman返回响应

然后可以重复上述修改 Request 的参数,点击 Send 去发送请求的过程,以便调试到 API 接口正常工作为止。

4.1.6 保存接口配置

待整个接口都调试完毕后,记得点击 Save 去保存接口信息:

Postman点击Save保存

去保存当前 API 接口,然后需要填写相关的接口信息:

  • Request Name: 请求的名字

    我一般习惯用保存为 接口的最后的字段名,比如http://{% raw %}{{% endraw %}{server_address}}/ucows/login/login中的/login/login

  • Request Description: 接口的描述

    可选 最好写上该接口的要实现的基本功能和相关注意事项

    支持 Markdown 语法

  • Select a collection or folder to save: 选择要保存到哪个分组(或文件夹)

    往往保存到某个 API 接口到所属的该项目名的分组

Postman保存时填写接口信息

填写好内容,选择好分组,再点击保存:

Postman保存到分组

此时,Tab 的右上角的黄色点(表示没有保存)消失了,表示已保存。

且对应的分组中可以看到对应的接口了:

Postman已保存的API接口Tab页

[warning] 默认不保存返回的 Response 数据

  • 直接点击 Save 去保存,只能保存 API 本身(的 Request 请求),不会保存 Response 的数据

  • 想要保存 Response 数据,需要用后面要介绍的 多个 Example

4.2 Request 的多参数操作详解

4.2.1 自动解析多个参数 Params

比如,对于一个 GET 的请求的 url 是: openapi.youdao.com/api?q=纠删码(E…

对应着其实是?key=value形式中包含多个 Http 的 GET 的 query string=query parameters

Postman 可以自动帮我们解析出对应参数,可以点击 Params:

Postman中GET时多个参数

看到展开的多个参数:

Postman中GET中展开的多个参数

如此就可以很方便的修改,增删对应的参数了。

4.2.2 临时禁用参数

且还支持,在不删除某参数的情况下,如果想要暂时不传参数,可以方便的通过不勾选的方式去实现:

Postman中不勾选个别参数

4.2.3 批量编辑 GET 的多个参数

当然,如果想要批量的编辑参数,可以点击右上角的Bulk Edit,去实现批量编辑。

Postman批量编辑GET参数

4.3 接口描述与自动生成文档

API 的描述中,也支持 Markdown,官方的接口说明文档:Intro to API documentation。

所以,可以很方便的添加有条理的接口描述,尤其是参数解释了:

Postman给Edit编辑

4.3.1 描述支持 markdown 语法

Postman支持Markdown写描述

而对于要解释的参数,可以通过之前的Param -> Bulk Edit的内容:

Postman批量更新参数

拷贝过来,再继续去编辑:

Postman编辑Markdown描述内容

以及添加更多解释信息:

Postman添加更多的Markdown内容

点击 Update 后,即可保存。

4.3.2 发布接口并生成 markdown 的描述文件

去发布后:

Postman去Publish Docs

对应的效果:有道翻译

Postman发布后Markdown效果

Postman发布后Markdown中代码效果

4.4 Response 深入

4.4.1 Response 数据显示模式

Postman 对于返回的 Response 数据,支持三种显示模式。

  • 默认格式化后的 Pretty 模式

Postman的Response的Pretty模式

  • Raw 原始模式

点击Raw,可以查看到返回的没有格式化之前的原始数据:

Postman的Response的Raw模式

  • Preview 预览模式

以及 Preview,是对应 Raw 原始格式的预览模式:

Postman的Response的Preview模式

Preview 这种模式的显示效果,好像是对于返回的是 html 页面这类,才比较有效果。

4.4.2 Response 的 Cookies

很多时候普通的 API 调用,倒是没有 Cookie 的:

Postman的响应中无Cookie

4.4.3 Response 的 Headers 头信息

举例,此处返回的是有 Headers 头信息的:

Postman的响应中的Headers

可以从中看到服务器是 Nginx 的。

4.5 保存多个 Example

之前想要实现,让导出的 API 文档中能看到接口返回的 Response 数据。后来发现是Example这个功能去实现此效果的。

4.5.1 如何添加 Example

Postman的接口点击Add Example

继续点击Save Example:

Postman的接口点击Save Example

保存后,就能看到Example(1)了:

Postman已保存的Example(1)

4.5.2 单个 Example 在导出的 API 文档中的效果

然后再去导出文档,导出文档中的确能看到返回数据的例子:

Postman导出API文档中带Example

4.5.3 多个 Example 在导出的 API 文档中的效果

Postman中多个Example在API文档中效果1

Postman中多个Example在API文档中效果2

4.6 其他好用的功能及工具

4.6.1 分组 Collection

在刚开始一个项目时,为了后续便于组织和管理,把同属该项目的多个 API,放在一组里

所以要先去新建一个 Collection: New -> Collection

Postman新建分组Colection

使用了段时间后,建了多个分组的效果:

Postman中的多个分组效果

单个分组展开后的效果:

Postman分组展开的效果

4.6.2 历史记录 History

Postman 支持 history 历史记录,显示出最近使用过的 API:

Postman的History显示历史记录

4.6.3 用环境变量实现多服务器版本

4.6.3.1 现存问题

在测试 API 期间,往往存在多种环境,对应 IP 地址(或域名也不同)

比如:

  • Prod: http://116.62.25.57/ucows

    用于开发完成发布到生产环境

  • Dev: http://123.206.191.125/ucows

    用于开发期间的线上的 Development 的测试环境

  • LocalTest: http://192.168.0.140:80/ucows

    用于开发期间配合后台开发人员的本地局域网内的本地环境,用于联合调试 API 接口

而在测试 API 期间,往往需要手动去修改 API 的地址:

Postman修改APi接口中服务器地址

效率比较低,且地址更换后之前地址就没法保留了。

另外,且根据不同 IP 地址(或者域名)也不容易识别是哪套环境。

4.6.2 Postman 支持用 Environment 环境变量去实现多服务器版本

后来发现 Postman 中,有 Environment 和 Global Variable,用于解决这个问题,实现不同环境的管理:

Postman中Environment和Globals

很明显,就可以用来实现不用手动修改 url 中的服务器地址,从而动态的实现,支持不同服务器环境:

  • Production 生产环境

  • Development 开发环境

  • Local 本地局域网环境

4.6.2.1 如何使用 Enviroment 实现多服务器版本

Postman中点击?的Add

或者:

Postman中点击设置Manage Enviroments

Postman中Manage Enviroments的Add

Environments are a group of variables & values, that allow you to quickly switch the context for your requests and collections.

Learn more about environments

You can declare a variable in an environment and give it a starting value, then use it in a request by putting the variable name within curly-braces. Create an environment to get started.

输入 Key 和 value:

Postman中Enviroment输入key和value

点击 Add 后:

Postman保存Enviroment

[info] 环境变量可以使用的地方

  • URL

  • URL params

  • Header values

  • form-data/url-encoded values

  • Raw body content

  • Helper fields

  • 写 test 测试脚本中

  • 通过 postman 的接口,获取或设置环境变量的值。

此处把之前的在 url 中的 IP 地址(或域名)换成环境变量:

Postman把IP换成环境变量

鼠标移动到环境变量上,可以动态显示出具体的值:

Postman环境变量鼠标动态提示

再去添加另外一个开发环境:

Postman添加Dev环境变量

则可添加完 2 个环境变量,表示两个服务器地址,两个版本:

Postman已添加2个环境变量

然后就可以切换不同服务器环境了:

Postman切换不同服务器环境

可以看到,同样的变量 server_address,在切换后对应 IP 地址就变成希望的开发环境的 IP 了:

Postman切换到Dev的IP地址

4.6.2.2 Postman 导出 API 文档中多个环境变量的效果

顺带也去看看,导出为 API 文档后,带了这种 Environment 的变量的接口,文档长什么样子:

发现是在发布之前,需要选择对应的环境的:

Postman发布前要选择环境

Postman选择某个环境

Postman已选择了某个环境

发布后的文档,可以看到所选环境和对应服务器的 IP 的:

Postman发布后看到所选环境的IP

当然发布文档后,也可以实时切换环境:

Postman发布后可以切换环境

Postman切换到某个环境看到IP

4.6.2.3 环境变量的好处

当更换服务器时,直接修改变量的 IP 地址:

Postman环境变量要更换IP地址

Postman环境变量更换为新IP

即可实时更新,当鼠标移动到变量上即可看到效果:

Postman鼠标移动到环境变量显示新IP

4.6.3 代码生成工具

4.6.3.1  查看当前请求的 HTTP 原始内容

对于当前的请求,还可以通过点击 Code

Postman中点击Code

去查看对应的符合 HTTP 协议的原始的内容:

Postman查看请求的Http的原始内容

4.6.3.2 各种语言的示例代码Code Generation Tools

比如:

  • Swift 语言

Postman把请求生成Swift代码

  • Java 语言

Postman把请求生成Java代码

  • 其他各种语言 还支持其他各种语言:

Postman把请求生成其他各种语言的代码

目前支持的语言有:

  • HTTP

  • C (LibCurl)

  • cURL

  • C#(RestSharp)

  • Go

  • Java

    OK HTTP

    Unirest

  • Javascript

  • NodeJS

  • Objective-C(NSURL)

  • OCaml(Cohttp)

  • PHP

  • Python

  • Ruby(NET::Http)

  • Shell

  • Swift(NSURL)

代码生成工具的好处是:在写调用此 API 的代码时,就可以参考对应代码,甚至拷贝粘贴对应代码,即可。

4.6.4 测试接口

选中某个分组后,点击 Runner

Postman中点击Runner

选中某个分组后点击 Run

Postman中点击Run去测试

即可看到测试结果:

Postman中测试API的结果

关于此功能的介绍可参考Postman 官网(www.getpostman.com/postman)的git 图(www.getpostman.com/img/v2/post…)

4.6.5 MockServer

直接参考官网。

4.7 功能界面

4.7.1 多 Tab 分页

Postman 支持多 tab 页,于此对比之前有些 API 调试工具就不支持多 Tab 页,比如Advanced Rest Client

多 tab 的好处:

方便在一个 tab 中测试,得到结果后,复制粘贴到另外的 tab 中,继续测试其它接口

比如此处 tab1 中,测试了获取验证码接口后,拷贝手机号和验证码,粘贴到 tab2 中,继续测试注册的接口

Postman拷贝Tab1中验证码

Postman粘贴验证码到Tab2

4.7.2 界面查看模式

Postman 的默认的 Request 和 Response 是上下布局:

Postman默认是上下布局

此处点击右下角的Two pane view,就变成左右的了:

Postman换成左右布局

[info] 左右布局的用途

对于数据量很大,又想要同时看到请求和返回的数据的时候,应该比较有用。

4.7.3 多颜色主题

Posman 支持两种主题:

  • 深色主题

当前是深色主题,效果很不错:

Postman的设置深色主题

Postman的深色主题的效果

  • 浅色主题

可以切换到 浅色主题:

Postman切换浅色主题

Postman浅色主题效果

4.8 API 文档生成

在服务端后台的开发人员测试好了接口后,打算把接口的各种信息发给使用此 API 的前端的移动端人员时,往往会遇到:

要么是用复制粘贴 -> 格式不友好 要么是用 Postman 中截图 -> 方便看,但是不方便获得 API 接口和字段等文字内容 要么是用 Postman 中导出为 JSON -> json 文件中信息太繁杂,不利于找到所需要的信息 要么是用文档,比如去编写 Markdown 文档 -> 但后续 API 的变更需要实时同步修改文档,也会很麻烦 这都会导致别人查看和使用 API 时很不方便。

-> 对此,Postman 提供了发布 API

预览和发布 API 文档 下面介绍 Postman 中如何预览和发布 API 文档。

4.8.1 简要概述步骤

  • Collection

  • 鼠标移动到某个 Collection,点击 三个点

  • Publish Docs

  • Publish

  • 得到 Public URL

  • 别人打开这个 Public URL,即可查看 API 文档

4.8.2 预览 API 文档

点击分组右边的大于号>

Postman的分组右边的>

如果只是预览,比如后台开发员自己查看 API 文档的话,可以选择:View in web

Postman的分组的View in web

等价于点击Publish Docs去发布:

Postman的分组点击Publish Docs

View in Web 后,有 Publish 的选项(见后面的截图)

View in Web 后,会打开预览页面:

比如:

奶牛云

documenter.getpostman.com/collection/…

Postman的API文档预览-1

Postman的API文档预览-2

而右边的示例代码,也可以从默认的 cURL 换成其他的:

示例代码从cURL换成Python

API文档中Python示例代码

4.8.3 发布 API 文档

如果想要让其他人能看到这个文档,则点击 Publish:

API文档中点击Publish去发布

然后会打开类似于这样的地址:

Postman Documenter

documenter.getpostman.com/collection/…

Postman确认发布分组的API文档

点击 Publish 后,可以生成对应的公开的网页地址:

Postman已发布文档得到公开链接

打开 API 接口文档地址:

documenter.getpostman.com/view/669382…

即可看到(和前面预览一样效果的 API 文档了):

Postman已发布的API文档效果

如此,别人即可查看对应的 API 接口文档。

4.9 已发布的 API 文档支持自动更新

后续如果自己的 API 接口修改后:

比如:

Postman去Edit编辑API

Postman的API更新编辑Edit Request

(后来发现,不用再去进入此预览和发布的流程,去更新文档,而是 Postman 自动支持)

别人去刷新该文档的页面:

documenter.getpostman.com/view/669382…

即可看到更新后的内容:

Postman自动更新了已发布的API文档

5

参考资料

主要参考:

  • **Github: **api_tool_postman(github.com/crifan/api_…

  • **Manage **environments(www.getpostman.com/docs/postma…

  • postman-变量/环境/过滤等 - 简书(www.jianshu.com/p/5d7954b6d…

  • Postman 使用手册 3——环境变量 - 简书(www.jianshu.com/p/bffbc79b4…

  • postman 使用之四:切换环境和设置读取变量 - 乔叶叶 - 博客园(www.cnblogs.com/qiaoyeye/p/…

本文作者:老马

原文发布于博客园

原文链接:

www.cnblogs.com/fly_dragon/…

以下是我们的社区介绍,欢迎各种合作、交流、学习:)

Postman接口测试神器从安装到精通相关推荐

  1. postman接口测试和charles安装ssl

    Measure_08 Postman接口测试 打开postman来到,将刚刚输入的网址copy到如下页面 请求完了,就得到了响应参数 其他操作 Charles charles安装ssl协议 Charl ...

  2. 接口测试软件Postman的下载及安装

    1. 操作环境 Windows Windows 7旗舰版 64位 Postman Postman-win64-5.1.3-Setup.exe 2. Postman的资源地址 1. 免费版下载 Post ...

  3. postman接口测试中文汉化教程

    小编热衷于收集整理资源,记录踩坑到爬坑的过程.希望能把自己所学,实际工作中使用的技术.学习方法.心得及踩过的一些坑,记录下来.也希望想做软件测试的你一样,通过我的分享可以少走一些弯路,可以形成一套自己 ...

  4. 一款技术人必备的接口测试神器:Apifox

    前言 今天,我想给大家推荐一款技术人必备的接口测试神器:Apifox,这个呢我就不多说废话了我们直接进入正题. 一. 背景 作为互联网行业技术从业者,接口调试是必不可少的一项技能,通常我们都会选择使用 ...

  5. 接口测试神器,它来了,它带着光环走来了

    推荐一款技术人必备的接口测试神器:Apifox 1. 背景 作为互联网行业技术从业者,接口调试是必不可少的一项技能,通常我们都会选择使用 Postman 这类工具来进行接口调试,在接口调试方面 Pos ...

  6. RestfulToolKit:便捷的 IDEA 接口测试神器

    RestfulToolKit:便捷的 IDEA 接口测试神器 1. RestfulToolKit 介绍 2. 安装 RestfulToolKit 3. 使用 RestfulToolKit 测试接口 4 ...

  7. 接口测试神器Apifox究竟有多香?

    前言 这篇文章介绍一款协作的工具Apifox,官方对Apifox的定位是Apifox = Postman +Swagger + Mack +JMeter. Apifox的强大之处可想而知.小伙伴们快来 ...

  8. 测试工具 - Postman接口测试入门使用手册,Postman如何进行数据关联、自动更新cookies、简单编程

    Postman 接口测试 前言 一.工具安装 ① 获取工具 ② 账号登录 ③ 抓包工具获取 二.接口测试 ① 创建一个目录 ② 编写脚本 ③ 抓取请求 ④ 填写用例头部 ⑤ 填写用例主体内容 ⑥ 测试 ...

  9. 思维导图 - 测试技术扩展:Postman接口测试、Sonar白盒测试、Sonic移动测试、Python操作FTP服务器

    给大家整理了下测试技术扩展相关的学习文档. 第一章: Postman 接口测试工具 测试工具 - Postman 接口测试入门使用手册,Postman 如何进行数据关联.自动更新 cookies.简单 ...

最新文章

  1. 2021年,深度学习还有哪些未饱和、有潜力且处于上升期的研究方向?
  2. appium简明教程(7)——Desired Capabilities详解
  3. Leaf:GO语言游戏框架介绍及入门
  4. 工作一年的状态与总结
  5. 数据挖掘 —— 半监督学习(标签传播算法)
  6. Amazon S3 设置对象的生命周期Lifecycle
  7. axios的get请求 - 代码篇
  8. flv 开源 修复_如何修复开源软件中的错误
  9. 精通开关电源设计第二版pdf_11、秋招年35月准备期——Verilog HDL高级数字设计(第二版)...
  10. 记一次无法登录 wine QQ
  11. java 区间api_Java 常用API(一)
  12. 大数据经典案例有哪些?
  13. MATLAB符号运算——积分
  14. u盘启动蓝屏 索尼vaio_索尼笔记本电脑安装系统后出现蓝屏怎么处理
  15. 佳能2206L复印机打印复印整体偏淡维修及检测
  16. 科创板交易规则知多少
  17. win10内存满载测试软件,高手亲自解决win10内存检测工具的详尽处理步骤
  18. stm32f4有重映射么_STM32 端口复用重映射(USART Remap)
  19. 支持ECSHOP 2.73手机客户端
  20. 启动到APP的设置页,小米手机自启动管理页,小米手机APP权限管理页

热门文章

  1. 信息系统项目管理师-信息系统范围管理核心知识点思维脑图
  2. HTML5中使用SpeechSynthesisAPI实现语音合成
  3. 快速上手用Python搭建自己的第一个pyecharts图表
  4. weblogic从入门到起飞(nodemanager)(五)
  5. 敏捷的项目启动-尽早启动!
  6. nanopi磁盘烧写
  7. java多线程有几种实现方法_Java多线程之间实现通讯
  8. @所有人,20 万大奖待领取!【全民找“BUG”】活动,等你!
  9. 一起教育科技携手神策数据,数据赋能智能教育新时代
  10. 机器学习中梯度下降算法的实际应用和技巧