背景描述
有一个项目要使用postman进行接口测试,接口所需参数有:
appid: 应用标识;
sign:请求签名,需要使用HMACSHA1加密算法计算,签名串是:{appid}u r l {url}url{stamp};
stamp:这个是时间戳;
option:业务参数;
问题是怎么在Postman发起请求时根据参数动态构建签名(sign)?
postman的脚本库中CryptoJS是支持各种算法的加密,包括HMACSHA1,签名算法有了。
难点是获取url中的path参数,当发起一个请求时开始可以固定一个path值的,自动化测试需要执行时获取path值,怎么获取呢?
创建一个GET请求
postman基础用法就不介绍了,先创建一个GET请求,URL中有配置各种动态参数
{{变量名}} :postman引用环境变量的语法;
{{$guid}}:postman预定义的环境变量用于获取一个GUID值;
在pre-request scripts构建签名
pre-request scripts 是个javascript执行环境,在请求发送之前执行;把他当做js用就行,不过有的js库是不支持的。
接下来就是动态获取签名了
1、appid环境变量中配置的固定值;
2、stamp时间戳获取:
-
//获取unix时间
-
getUnixTime:function(){
-
return Math.round(new Date().getTime()/1000);
-
}
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();
结果如图:
代码如下:
-
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+"$"+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();
其实就是将postmanUtil放入环境变量了,其它没有变,只要维护环境变量里的值就OK了,不用一个个去改。
再看pre-request script代码,这样就简单多了:
postman console的用法
不知道是否成功获取了环境变量,又或者想查看某个变量的值,postman也提供了很方便的控制台查看,菜单View下Show Postman Console可以打开如下控制台
图中是console.log(sercret)和sendRequest()的结果
Collection Runner 自动化API测试
创建接口的测试用例
对于返回html的结果,只要测试body中包含某个值就算通过
对于返回Json结果,只要Code为0即为通过
窗口右侧有常用的脚本快捷操作,选中就可以生成,很方便
选择并运行自动化接口测试
点击主页左上角Runner进入,选择之前构建好的接口,并选择好环境,点击Run xxx接口运行脚本测试
测试结果
可以看到结果2接口都成功返回预定的结果
总结:
感谢每一个认真阅读我文章的人!!!
作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。
软件测试面试文档
我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。