发布时间:2024-11-22 11:01
有一个项目要使用postman进行接口测试,接口所需参数有:
appid: 应用标识;
sign:请求签名,需要使用HMACSHA1加密算法计算,签名串是:{appid}${url}${stamp};
stamp:这个是时间戳;
option:业务参数;
问题是怎么在Postman发起请求时根据参数动态构建签名(sign)?
postman的脚本库中CryptoJS是支持各种算法的加密,包括HMACSHA1,签名算法有了。
难点是获取url中的path参数,当发起一个请求时开始可以固定一个path值的,自动化测试需要执行时获取path值,怎么获取呢?
postman基础用法就不介绍了,先创建一个GET请求,URL中有配置各种动态参数
{{变量名}} :postman引用环境变量的语法;
{{$guid}}:postman预定义的环境变量用于获取一个GUID值;
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();
在Pre-request Script写上面代码,要是单个接口还是可以的,即使很多接口只要Copy一份即可。
万一脚本需要改麻烦就来了,你需要去每个请求的 Pre-request Script窗口改,怎么解决呢?
可以解决,将postmanUtil定在ENVIRONMENT中就可以了,做法如下:
其实就是将postmanUtil放入环境变量了,其它没有变,只要维护环境变量里的值就OK了,不用一个个去改。
再看pre-request script代码,这样就简单多了:
不知道是否成功获取了环境变量,又或者想查看某个变量的值,postman也提供了很方便的控制台查看,菜单View下Show Postman Console可以打开如下控制台:
图中是console.log(sercret) 和 sendRequest()的结果
创建接口的测试用例
对于返回html的结果,只要测试body中包含某个值就算通过
对于返回Json结果,只要Code为0即为通过
窗口右侧有常用的脚本快捷操作,选中就可以生成,很方便
点击主页左上角Runner进入,选择之前构建好的接口,并选择好环境,点击Run xxx 接口运行脚本测试
可以看到结果2接口都成功返回预定的结果
下面是一份配套资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!
这些都可以以在公众号:伤心的辣条 ! 免费领取,还有一份216页软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!,其中资料包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。
学习不要孤军奋战,最好是能抱团取暖,相互成就一起成长,群众效应的效果是非常强大的,大家一起学习,一起打卡,会更有学习动力,也更能坚持下去。你可以加入我们的测试技术交流扣扣群:914172719(里面有各种软件测试资源和技术讨论)
喜欢软件测试的小伙伴们,如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!
转行面试,跳槽面试,软件测试人员都必须知道的这几种面试技巧!
面试经:一线城市搬砖!又面软件测试岗,5000就知足了…
面试官:工作三年,还来面初级测试?恐怕你的软件测试工程师的头衔要加双引号…
什么样的人适合从事软件测试工作?
那个准点下班的人,比我先升职了…
测试岗反复跳槽,跳着跳着就跳没了…
华为回应与陈春花教授相关传言;iPhone14Pro系列将独占A16芯片;Bug太多,Python 3.11推迟发布|极客头条
学会在Vue项目中插入高德地图JS API与地图的相关设置,看这一篇就够了~(保姆级精简教学)
【C语言】字符串函数及模拟实现strlen&&strcpy&&strcat&&strcmp
flutter系列之:Material主题的基础-MaterialApp
ArrayList源码深度剖析,从最基本的扩容原理,到魔幻的迭代器和fast-fail机制,你想要的这都有!!!
ros(26):ros::Time::now(),ros::Duration,toSec(),toNSec();计算程序执行时间
论文阅读笔记 | Transformer系列——Transformer in Transformer
学习笔记( 11 ) - 解决:finalshell连接虚拟机(ubuntu)超时,主机ping不通虚拟机,主机没有VMnet8网卡, Connection refused: connect