jmeter调用python脚本获取sign加签值

一、参数化(局部或全局变量)
jmeter调用python脚本获取sign加签值_第1张图片
二、添加Jsr223 sampler组件,选择python语言,录入需要传递给脚本 的变量参数 ,用;分隔jmeter调用python脚本获取sign加签值_第2张图片
然后编写pythone脚本,建议脚本在编辑工具调试通过后粘贴过来。
如上实例是对请求参数排序后取MD5值,当作sign加签,附对应脚本

import hashlib
appKey = "fc49291a7a4d4b438fb00e77a3639406"
appSecret = "8b2fccea892343b59ff925ab67a579de"
#以下两种写法都可以
#BeanShell取变量值
accessToken = vars.get("accessToken_1")
deviceId = vars.get("deviceId")
#python取变量值
accessToken = "${accessToken_1}"
deviceId = "${deviceId}"

#def get_sign():
data = {
     
   "accessToken": accessToken,
   "deviceId": deviceId,
   "setParams": "{'self_checking':true}"
}
if 'appKey' not in data.keys():
   data['appKey'] = appKey
if 'sign' in list(data.keys()):
   del data['sign']
sign_str = ''
for k in sorted(data.keys()):
   key = data[k]
   sign_str += '{0}={1}&'.format(k, key)
sign_str += appSecret
print('待加密字符串为:', sign_str)
result = hashlib.md5(sign_str.encode("utf-8")).hexdigest()
#return result
print("sign值为:", result)    
vars.put("sign",result)	//BeanShell脚本

三、脚本编写完成后,运行线程组,调试。可以在结果树中查看Jsr223取样器的变量传递是否正确,传递的变量会有颜色高亮显示,如图。
如果取值异常,也会在取样器结果中看到异常信息,再针对性调试分析
jmeter调用python脚本获取sign加签值_第3张图片
最后检查http请求的请求参数是否正确

你可能感兴趣的:(jmeter)