目录

使用postman做接口测试

使用postman做接口测试

一、postman的基础应用

1. 请求部分

https://i-blog.csdnimg.cn/blog_migrate/c0ce618948ac56828c4c86219bc2e71e.png

2. 请求部分body

https://i-blog.csdnimg.cn/blog_migrate/81e2b1cd0964af4bbc2685e74fac547d.png

3. 响应部分

https://i-blog.csdnimg.cn/blog_migrate/f0211cb2f8781eb94d32aca900fa5187.png

https://i-blog.csdnimg.cn/blog_migrate/b8ff0c5f80b2f4460ee8caa94b96c852.png

二、接口关联

接口关联:下一个接口的参数使用了上一个接口的返回值

1. 使用json.parse格式

首先找到有返回值的接口的Tests,将其参数设置为全局变量,以便其他接口使用

设置全局变量

pm.globals.set()

https://i-blog.csdnimg.cn/blog_migrate/52efe4fd462370a455299129b118f486.png

使用全局变量(后面都同理)

在参数位置打印两个大括号,会自动弹出全局变量信息,选中需要的全局变量即可。

https://i-blog.csdnimg.cn/blog_migrate/a5d972412660d6c2c627b40c464dbb18.png

2. 使用正则表达式

设置全局变量

https://i-blog.csdnimg.cn/blog_migrate/e153edc9c7e2e592768f97fa965ab8cb.png

3. 使用cookie

https://i-blog.csdnimg.cn/blog_migrate/b9f45b2eff8935aad17fe1a1406881e1.png

4. 使用请求头(Header)

https://i-blog.csdnimg.cn/blog_migrate/43788cc30e826b4cfaf4b4113149cb46.png

三、设置动态参数

注意:postman内置的动态参数无法进行断言,必须使用自定义动态参数!

1. 内置动态参数

{ {$timestamp}}  –  生成当前时间的时间戳

{ {$randomInt}}  –  生成0-1000之间的随机整数

{ {$guid}}  –  生成随机的guid字符串值

2. 自定义动态参数

实现时间戳

获取

https://i-blog.csdnimg.cn/blog_migrate/a9444902d86f15af48d80d14ce388d42.png

使用

https://i-blog.csdnimg.cn/blog_migrate/a1d35251a8406e980ca7b09cc861ac1f.png

实现等待3秒

const sleep = (milliseconds) => {
    const start = Date.now();
    while (Date.now() <= start + milliseconds) {}
};
sleep(3000);

四、环境变量和全局变量

全局变量

可以在Environments的Globals里面配置全局变量可以供所有接口去使用:规则{ {全局变量名字}}

https://i-blog.csdnimg.cn/blog_migrate/4296414292fec055ce40d413ecc27589.png

环境变量

环境变量:开发环境,测试环境,线上环境

主要用于环境的不同指定的ip和端口号不同然后去发送同样的请求

https://i-blog.csdnimg.cn/blog_migrate/694edd8c1a0e4246f28880dba7b83123.png

https://i-blog.csdnimg.cn/blog_migrate/d8a90b3212e4b2c2b0828509f4e8239a.png

五、断言

使用

断言一般在接口Tests部分使用,目的是为了效验接口的响应信息是否符合预期

//1. 检查状态码
pm.test("Status code is 200", function () {
    pm.response.to.have.status(200);
});
//2. 检查响应体重还发包含该字符串
pm.test("Body matches string", function () {
    pm.expect(pm.response.text()).to.include("string_you_want_to_search");
});
//3. 检查json中某个字段的值
pm.test("Your test name", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData.value).to.eql(100);
});
//4. 检查响应中body中指定的字符串
pm.test("Body is correct", function () {
    pm.response.to.have.body("response_body_string");
});
//5. 检查是否包含某响应头
pm.test("Content-Type is present", function () {
    pm.response.to.have.header("Content-Type");
});
//6. 检查请求消耗的时间是否小于xxms
pm.test("Response time is less than 200ms", function () {
    pm.expect(pm.response.responseTime).to.be.below(200);
});

https://i-blog.csdnimg.cn/blog_migrate/bb6e0e0e57e3628e63317dec03b04fe2.png

https://i-blog.csdnimg.cn/blog_migrate/43599b72f7ca446d827c1fe781a7b558.png

https://i-blog.csdnimg.cn/blog_migrate/bac75e1a6c59adc8b20e499d12b93165.png

与自定义参数搭配使用

再讲动态参数时有提到过: postman内置的动态参数无法进行断言,必须使用自定义动态参数!

其原因就是在断言内容部分无法使用{ {xxx}}的方式将参数传递进去,只能使用字符串拼接的方式将参数传入

举例:

使用内置参数

https://i-blog.csdnimg.cn/blog_migrate/f099d538267c3fa74019e34e4c5bf822.png

可以看到,内置参数并没有进行解析,自定义参数也是同理(这里不演示了)。

我们可以将自定义参数通过pm.globals.get(“xxx”) / globals[“xxx”] / globals.xxx (xxx为全局参数名)的方式将自定义参数的内容提取出,然后在进行字符串拼接。如下。(注意:传参部分也要对应修改)

https://i-blog.csdnimg.cn/blog_migrate/2541d7d7f78a52643737f80463f35af5.png

六、接口测试必带请求头信息设置

在测试不同接口的时候可能需要配置一些必带请求头参数才会返回完整的响应体,所以需要用户自行在请求头中配置参数

特殊的:

  1. 在遇到请求头无法更改的情况,可以将原请求头取消掉,然后新增一个请求头填写参数

https://i-blog.csdnimg.cn/blog_migrate/590c92322633ca6f5455eeb6066ccd3b.png

  1. 一般必带请求头会在接口文档中描述具体,如果不清楚需要携带哪些请求头,可以通过抓包工具Fiddler获取所有请求头信息,复制到postman中使用

步骤一:抓包,复制请求头信息

https://i-blog.csdnimg.cn/blog_migrate/899e9b17505fbc284d82b899b1752c35.jpeg

步骤二:点击postman请求头的批量编辑按钮

https://i-blog.csdnimg.cn/blog_migrate/c033bacbe6b279969d261108c6ef741e.png

步骤三:将复制的内容粘贴进来,并回到key-value编辑

https://i-blog.csdnimg.cn/blog_migrate/3afb1d68f2ad971843d902b22eb5a2df.png

七、接口鉴权

接口鉴权常用的有两种:

https://i-blog.csdnimg.cn/blog_migrate/e482d6bf25f1234093b6c986e5427ee5.png

Bearer Token:发送一个token令牌,服务器针对token进行解密验证

https://i-blog.csdnimg.cn/blog_migrate/a12180e1a6ea483a157686d66fd6d970.png

Basic Auth:基础验证,提供用户名和密码进行验证,postman会自动生成鉴权码

https://i-blog.csdnimg.cn/blog_migrate/b1dc80c968b596733868c5d03c97436c.png