在我们使用Jmeter测试的过程中,尤其是接口测试,有时候需要对参数进行MD5加密后再进行操作。
Jmeter自带的就有MD5加密需要使用的到的jar,在jmeter的lib目录下面。
使用时要引入MD5加密所需要的jar包。该jar包的名字是:commons-codec-1.10.jar,注意jmeter版本,不同版本jar包版本也会不同!!!
Jmeter本身就有MD5加密的功能,但是需要该jar包,可以查看Jmeter安装路径下的lib文件夹在有没有这个jar包:D:\apache-jmeter\apache-jmeter\lib
如果没有的话,网上下载一个放到lib文件夹下就OK了。
编写MD5加密-请求验签的脚本步骤:
1.编写该脚本需要新建的东西如下:
A.添加一个线程组:测试计划——添加——线程(用户)——线程组
B.线程组下添加一个 前置处理器 BeanShell PreProcessor:线程组——添加——前置处理器——BeanShell PreProcessor
(BeanShell PreProcessor 主要是用来完成加密字符串的拼接和MD5 加密)
C.线程组下面添加一个 HTTP信息头管理器 :线程组——添加——配置元件——HTTP信息头管理器。
用于设置请求信息头里面的参数。
D.线程组下添加一个 HTTP请求:线程组——添加——取样器——HTTP请求。
E.最后添加 察看结果树 和 聚合报告 :线程组——添加——监听器—— 察看结果树 / 聚合报告
察看结果树的目的是用于:查看我们的请求是否访问成功,已经请求内容和返回内容是否正确
聚合报告:主要是用于统计总的请求数,平均请求时间,响应时长,Err 数,Err率等数据。
2.新建脚本的模型成功后,开始填充脚本的内容,完成脚本MD5加密功能。
A.在前置处理器 BeanShell PreProcessor添加如下内容:
Jmeter 5 自带 org.apache.commons.codec.digest jar,所以只需要导入就可以了。
字符串的顺序拼接规则是:按照参数的首字母,对参数进行A-Z的顺序进行排序,并拼接,可以参见图中参数的排序规则。
字符相互之间连接类似:
appVersion=V1.0.0&clientType=XXX&productId=XXX&source=XXX,注:不同公司的拼接规则不同,需询问开发具体的拼接规则
// 导入MD5加密需要用到的jar包。
import org.apache.commons.codec.digest.DigestUtils;
// 声明你需要拼接的字符串
String requestTime = "${__time(,)}"; //生成时间戳
String appVersion ="XXX";
String clientType ="XXX";
String productId ="XXX";
String source ="XXX";
//拼接需要加密的字符串
String str = "appVersion="+appVersion+"&clientType="+clientType+"&productId="+productId +"&requestTime="+requestTime+"&source="+source+"istarkid2018";
// 加密已拼接的字符串
String sign = DigestUtils.md5Hex(str);
vars.put("signStr",sign.toString()); //把生成的signStr提供给beanshell外部组件引用
vars.put("requestTime",requestTime.toString()); //把生成的时间戳提供给beanshell外部组件引用
vars.put("appVersion",appVersion.toString()); //把生成的版本号提供给beanshell外部组件引用
vars.put("clientType",clientType.toString()); //把生成的clientType提供给beanshell外部组件引用
生成时间戳,方法较多,不同公司所用的时间戳生成方法不同,这点需要询问开发具体的生成规则,以下提供几种生成规则:
生成十三位时间戳:${__time(,)}
生成十位时间戳:${__time(/1000,)}
生成当前日期,精确到天时间戳:${__time(yyyy-MM-dd,)}
生成当前日期,精确到秒时间戳:${__time(YMDHMS,)}
以上并是一个加了MD5和验签的脚本的具体流程,若有错误的地方,请大家多多指点~