2024年postman接口测试实战讲解,2024年最新软件测试架构师必备技术

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

}



3、url值可以通过`request.url`获取然后解析出其中的path:




//获取url的path部分
getUrlRelativePath:function(url){
var arrUrl = url.split(“//”);
    var start = arrUrl[1].indexOf(“/”);
    var end=arrUrl[1].indexOf(“?”);
    var relUrl = arrUrl[1].substring(start,end);//stop省略,截取从start开始到结尾的所有字符
    console.log(relUrl);
return relUrl;
}



4、构造签名串,使用秘钥加密即可。


postman提供的加密算法库并不一定所有都支持,有时候需要向后台去换取签名;




var host=pm.environment.get(“host”);
var text=encodeURIComponent(plain);
pm.sendRequest(host+“/FaceIn/ToHmacsha1?plain=”+text+“&secret=”+sercret, function (err, response) {
var json=response.json();
//签名含有+等特殊字符需要url编码
pm.environment.set(“sign”,encodeURIComponent(json.result));
});



签名串最好进行URL编码。



> 
> **遗留问题:**向后台换取签名的时候起初是返回字符串responsejson()解析不了的!
> 
> 
> 


5、使用eval将定义的变量postmanUtil注入全局变量中然后调用




eval(environment.postmanUtil);
postmanUtil.setLsdzSign();



结果如图:




[![图2](https://img-blog.csdnimg.cn/img_convert/d6e53f10f83fc293f89dca17bfd9b678.png)](https://images.cnblogs.com/cnblogs_com/ricolee/1504807/o_181129-postman-pre.png?t=5)​



代码如下:




var postmanUtil={
//获取unix时间
getUnixTime:function(){
return Math.round(new Date().getTime()/1000);
},
//获取url的path部分
getUrlRelativePath:function(url){
var arrUrl = url.split(“//”);
    var start = arrUrl[1].indexOf(“/”);
    var end=arrUrl[1].indexOf(“?”);
    var relUrl = arrUrl[1].substring(start,end);//stop省略,截取从start开始到结尾的所有字符
    console.log(relUrl);
return relUrl;
},
//签名
setLsdzSign:function(){
var appid=pm.environment.get(“appid”);
var sercret=pm.environment.get(“appsercret”);
//时间戳
var time=postmanUtil.getUnixTime();
pm.environment.set(“stamp”, time);
//地址 获取当前地址的path部分
var path= postmanUtil.getUrlRelativePath(request.url);
console.log(path);
var url=path;
var plain=appid+“ " + u r l . t o L o w e r C a s e ( ) + " "+url.toLowerCase()+" "+url.toLowerCase()+"”+time;
var hmac = CryptoJS.HmacSHA1(plain, sercret).toString(CryptoJS.enc.Base64);
//获取签名,CryptoJS.HmacSHA1 无法满足签名算法只能从后台
var host=pm.environment.get(“host”);
var text=encodeURIComponent(plain);
pm.sendRequest(host+“/FaceIn/ToHmacsha1?plain=”+text+“&secret=”+sercret, function (err, response) {
var json=response.json();
//签名含有+等特殊字符需要url编码
pm.environment.set(“sign”,encodeURIComponent(json.result));
});
}
}
eval(environment.postmanUtil);
postmanUtil.setLsdzSign();



### 脚本写在环境变量中


在Pre-request Script写上面代码,要是单个接口还是可以的,即使很多接口只要Copy一份即可。


万一脚本需要改麻烦就来了,你需要去每个请求的 Pre-request Script窗口改,怎么解决呢?


可以解决,将`postmanUtil`定在`ENVIRONMENT`中就可以了,做法如下:




[![图3](https://img-blog.csdnimg.cn/img_convert/fbaaf1e7e469a772707ac052538e4528.png)](https://images.cnblogs.com/cnblogs_com/ricolee/1504807/o_181129-postman-enviroment.png?t=5)​



其实就是将`postmanUtil`放入环境变量了,其它没有变,只要维护环境变量里的值就OK了,不用一个个去改。


再看`pre-request script`代码,这样就简单多了:




[![图4](https://img-blog.csdnimg.cn/img_convert/c8ea05c8c76ca37afa079cf223d1a8b8.png)](https://images.cnblogs.com/cnblogs_com/ricolee/1504807/o_181129-postman-auto-script.png?t=5)​



### postman console的用法


不知道是否成功获取了环境变量,又或者想查看某个变量的值,postman也提供了很方便的控制台查看,菜单`View`下`Show Postman Console`可以打开如下控制台:




[![图5](https://img-blog.csdnimg.cn/img_convert/0c65b519038e66a86eae0af6c7db4ff6.png)](https://images.cnblogs.com/cnblogs_com/ricolee/1504807/o_181129-postman-console.png?t=5)​



图中是`console.log(sercret)` 和 `sendRequest()`的结果


### Collection Runner 自动化API测试


#### 创建接口的测试用例


对于返回html的结果,只要测试body中包含某个值就算通过




[![图6](https://img-blog.csdnimg.cn/img_convert/454118327392bc43aaac99d4700e6822.png)](https://images.cnblogs.com/cnblogs_com/ricolee/1504807/o_181129-postman-runner-test.png?t=5)​



对于返回Json结果,只要Code为0即为通过




[![图7](https://img-blog.csdnimg.cn/img_convert/d35e01c76c372832e122497c03f48996.png)](https://images.cnblogs.com/cnblogs_com/ricolee/1504807/o_181129-postman-runner-test-json.png?t=5)​




> 
> 窗口右侧有常用的脚本快捷操作,选中就可以生成,很方便
> 
> 


![img](https://img-blog.csdnimg.cn/img_convert/d75bdc7c51d09efd56bf0493a40b8fb0.png)
![img](https://img-blog.csdnimg.cn/img_convert/33964a5328460e420fa3219ab084cc9e.png)
![img](https://img-blog.csdnimg.cn/img_convert/7d94f394831c44435623b3bde61f3957.png)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[需要这份系统化的资料的朋友,可以戳这里获取](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)**

础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[需要这份系统化的资料的朋友,可以戳这里获取](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)**

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值