网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事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)**