随着web技术的发展,特别是前后端分离的架构主键成为主流,我们后端程序员调试的时候不再依赖页面去操作,而是直接调试接口。对于没有权限控制的GET接口而言,这是一个非常轻松的工作,但是对于有权限的或者使用了其他方法(POST,PUT,DELETE等)的Rest接口,事情就不那么美好了,还好有postman这个神器能够帮我们解决这些问题,基本的使用我就不讲了,这一块网上的教程很多。这里主要提一些相对来说比较高级的用法。

环境设置

这其实也算是一个比较基本的功能了,由于跟后续的操作相关,所以也提一下。刚使用postman的时候我还不熟悉,于是傻傻的给每套环境配了一项配置。其实postman的开发者早就想到了这种情况,postman提供了环境变量的设置,相信这点大家都很熟悉。放在这个例子里就很直观了,我们配置相应的3套环境就可以了,如下图所示:

选择右上角红色区域,下拉框中选择Management Environments就可以进入图示的环境编辑页面,我这里增加了三套环境

shiro postman请求头里面加sessionid_后端

以下以线上环境为例:编辑url的环境变量:

shiro postman请求头里面加sessionid_postman_02

shiro postman请求头里面加sessionid_postman_03

环境配置里面可以编辑key-value的环境变量,环境变量配置好了之后该怎么使用呢。这个也比较简单,形如{{keyname}}这样就可以了,环境变量可以应用的地方有URL、URL参数、header、header presets、authorization、body这些地方。如上例的url

shiro postman请求头里面加sessionid_json_04

 

变量

在环境设置里面,我们提到了在环境里面配置环境变量,事实上,变量不止这样一种类型,一共有四个类型

全局变量

环境变量

局部变量

数据(只能在Collection runner中使用)

他们的覆盖优先级是从高到低,也就是说数据是最高优先级的,全局的是最低的。数据变量实际上就是外部加载的数据,比如本地CSV或者JSON文件。

 

Test scripts

测试脚本是在发送请求之后并且从服务器接收到响应时执行。

 

设置环境变量

pm.environment.set("variable_key", "variable_value");
 
将一个嵌套的对象设置为一个环境变量 
var array = [1, 2, 3, 4];
pm.environment.set("array", JSON.stringify(array, null, 2));
var obj = { a: [1, 2, 3, 4], b: { c: 'val' } };
pm.environment.set("obj", JSON.stringify(obj))
 
获得一个环境变量
pm.environment.get("variable_key");
 
获得一个环境变量(其值是一个字符串化的对象)
// These statements should be wrapped in a try-catch block if the data is coming from an unknown source.
var array = JSON.parse(pm.environment.get("array"));
var obj = JSON.parse(pm.environment.get("obj"));
 
清除一个环境变量
pm.environment.unset("variable_key");
 
设置一个全局变量
pm.globals.set("variable_key", "variable_value");
  
获取一个全局变量
pm.globals.get("variable_key");
  
清除一个全局变量
pm.globals.unset("variable_key");
 
获取一个变量
该函数在全局变量和活动环境中搜索变量
pm.variables.get("variable_key");
 
检查响应主体是否包含字符串
pm.test("Body matches string", function () {
 pm.expect(pm.response.text()).to.include("string_you_want_to_search");
});
  
检查响应体是否等于字符串
pm.test("Body is correct", function () {
  pm.response.to.have.body("response_body_string");
 });
 
检查JSON值
 pm.test("Your test name", function () {
   var jsonData = pm.response.json();
   pm.expect(jsonData.value).to.eql(100); 
});
 
Content-Type 存在
pm.test("Content-Type is present", function () {
  pm.response.to.have.header("Content-Type");
});
  
返回时间少于200ms
pm.test("Response time is less than 200ms", function () {
    pm.expect(pm.response.responseTime).to.be.below(200);
});
 
状态码是200
pm.test("Status code is 200", function () {
    pm.response.to.have.status(200); 
});
 
代码名包含一个字符串 
pm.test("Status code name has string", function () {
  pm.response.to.have.status("Created");
});
 
成功的POST请求状态码
pm.test("Successful POST request", function () {
    pm.expect(pm.response.code).to.be.oneOf([201,202]);
});
 
为JSON数据使用TinyValidator
var schema = {
 "items": {
 "type": "boolean" 
 } 
}; 
var data1 = [true, false];
var data2 = [true, 123];
pm.test('Schema is valid', function() {
  pm.expect(tv4.validate(data1, schema)).to.be.true;
  pm.expect(tv4.validate(data2, schema)).to.be.true;
});
 
解码base64编码数据
var intermediate,
    base64Content, // assume this has a base64 encoded value
    rawContent = base64Content.slice('data:application/octet-stream;base64,'.length);
intermediate = CryptoJS.enc.Base64.parse(base64content); // CryptoJS is an inbuilt object, documented here: https://www.npmjs.com/package/crypto-js 
pm.test('Contents are valid', function() { 
  pm.expect(CryptoJS.enc.Utf8.stringify(intermediate)).to.be.true; // a check for non-emptiness
});
 
发送异步请求
此函数可作为预请求和测试脚本使用
pm.sendRequest("https://postman-echo.com/get", function (err, response) {
    console.log(response.json()); 
});

 

将XML主体转换为JSON对象

var jsonObject = xml2Json(responseBody);

 

如下例子:判断接口响应是否是200,判断接口字段view-type字段是否返回0

shiro postman请求头里面加sessionid_json_05