• postman接口测试实战讲解


    背景描述
    有一个项目要使用postman进行接口测试,接口所需参数有:

    appid: 应用标识;
    sign:请求签名,需要使用HMACSHA1加密算法计算,签名串是:{appid}${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时间戳获取:

    1. //获取unix时间
    2. getUnixTime:function(){
    3. return Math.round(new Date().getTime()/1000);
    4. }

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

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

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

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

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

    签名串最好进行URL编码。

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

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

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

     结果如图:

    代码如下:

    1. var postmanUtil={
    2. //获取unix时间
    3. getUnixTime:function(){
    4. return Math.round(new Date().getTime()/1000);
    5. },
    6. //获取url的path部分
    7. getUrlRelativePath:function(url){
    8. var arrUrl = url.split("//");
    9.     var start = arrUrl[1].indexOf("/");
    10.     var end=arrUrl[1].indexOf("?");
    11.     var relUrl = arrUrl[1].substring(start,end);//stop省略,截取从start开始到结尾的所有字符
    12.     console.log(relUrl);
    13. return relUrl;
    14. },
    15. //签名
    16. setLsdzSign:function(){
    17. var appid=pm.environment.get("appid");
    18. var sercret=pm.environment.get("appsercret");
    19. //时间戳
    20. var time=postmanUtil.getUnixTime();
    21. pm.environment.set("stamp", time);
    22. //地址 获取当前地址的path部分
    23. var path= postmanUtil.getUrlRelativePath(request.url);
    24. console.log(path);
    25. var url=path;
    26. var plain=appid+"$"+url.toLowerCase()+"$"+time;
    27. var hmac = CryptoJS.HmacSHA1(plain, sercret).toString(CryptoJS.enc.Base64);
    28. //获取签名,CryptoJS.HmacSHA1 无法满足签名算法只能从后台
    29. var host=pm.environment.get("host");
    30. var text=encodeURIComponent(plain);
    31. pm.sendRequest(host+"/FaceIn/ToHmacsha1?plain="+text+"&secret="+sercret, function (err, response) {
    32. var json=response.json();
    33. //签名含有+等特殊字符需要url编码
    34. pm.environment.set("sign",encodeURIComponent(json.result));
    35. });
    36. }
    37. }
    38. eval(environment.postmanUtil);
    39. postmanUtil.setLsdzSign();

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

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

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

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

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

    postman console的用法

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

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

    Collection Runner 自动化API测试

    创建接口的测试用例

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

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

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

    选择并运行自动化接口测试

    点击主页左上角Runner进入,选择之前构建好的接口,并选择好环境,点击Run xxx 接口运行脚本测试

    测试结果

    可以看到结果2接口都成功返回预定的结果

    最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

    文档获取方式:

    这份文档,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

    以上均可以分享,只需要你搜索vx公众号:程序员雨果,即可免费领取

  • 相关阅读:
    大数据导论考察论文
    JS 树形数据处理
    c++ 内存顺序
    基于JavaWeb+SpringBoot+微信小程序的酒店商品配送平台系统的设计和实现
    深入 K8s 网络原理(二)- Service iptables 模式分析
    项目实战第三十六讲:基于 Sharding-JDBC 的商品分库⽅案
    java读取csv文件或者java读取字符串,找出引号内容,采用正则表达式书写
    [杂谈]-电动汽车有哪些不同类型
    用Blender制作YOLO目标检测器训练数据
    Qt QLable 字符过长省略
  • 原文地址:https://blog.csdn.net/2301_77645750/article/details/132813364