芙蓉区网站建设公司,wordpress二级菜单,yande搜索引擎官网入口,建站自助写接口脚本的时候#xff0c;很多接口涉及到签名#xff0c;今天介绍下用JMeter编写签名脚本的方法。
举个例子#xff0c;开启红包接口#xff0c;请求方式为post
POST /v1/api/red/open
json请求参数
{
red_id:1,
timestamp:1667033841…
写接口脚本的时候很多接口涉及到签名今天介绍下用JMeter编写签名脚本的方法。
举个例子开启红包接口请求方式为post
POST /v1/api/red/open
json请求参数
{
red_id:1,
timestamp:1667033841,
}算法
1、将请求参数按照键名进行升序排序需要带上时间戳
2、拼接秘钥将秘钥拼接在参数后面
3、将拼接后的结果取md5值
4、取hash值
JMeter脚本的结构如下用户自定义变量key找开发同学要随机变量红包获取红包idBean Shell PreProcessor获取当前时间戳。 结构分析
1、用户自定义变量key找开发同学要 2、随机变量红包获取红包id是1到100的数字 3、获取当前时间戳Bean Shell PreProcessor
代码
import java.util.Map;
import java.lang.String;
timestamp System.currentTimeMillis()/1000;
vars.put(timestamp,timestamp.toString());4、HTTP请求开启红包 sign的计算方法
先将请求参数按照键名进行升序排序需要带上时间戳也就是red_idKaTeX parse error: Expected EOF, got at position 9: {red_id}̲timestamp{timestamp}再拼接keyred_idKaTeX parse error: Expected EOF, got at position 9: {red_id}̲timestamp{timestamp}${key}取MD5值,可在函数助手中生成。 再取hash值需要注意是哪种算法有的是SHA-1有的是SHA-256 调试小技巧
如果页面功能已经完成了可以在页面上先抓包将脚本的所有变量例如red_idtimestamp都换成与抓包一样的值通过自己的脚本算出sign值看是否与页面一致如果一致则正确。
最后感谢每一个认真阅读我文章的人礼尚往来总是要有的虽然不是什么很值钱的东西如果你用得到的话可以直接拿走 这些资料对于【软件测试】的朋友来说应该是最全面最完整的备战仓库这个仓库也陪伴上万个测试工程师们走过最艰难的路程希望也能帮助到你