JMeter安装配置
从下载JMeter的软件包apache-jmeter-x.x.zip,下载完成之后解压打开jmeter.bat即可。
说明
这里使用的jmeter版本是3.0,jdk版本是jdk1.8;目前最新版本jmeter3.3支持的是jdk1.8版本,不支持jdk1.9的版本。
jmeter打开的界面如图所示
整个接口项目的结构示意图如下
今天主要记录时间戳和md5加密的方法。
如何在jmeter中获取当前系统的时间戳呢?jmeter系统提供了方法${__time(,)}
,使用该方法可以获取当前系统的毫秒格式的时间戳。
md5加密的实现
那么md5加密如何实现呢?
这里是引入jar包来实现md5-32位加密。
从网上copy了一份md5加密的代码如下
package com.test;import java.io.UnsupportedEncodingException;import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;/** * MD5加密 * * @param str * @return */public class mymd5 {public static String md5(String str) { if(null == str){ return null; } try { MessageDigest md = MessageDigest.getInstance("MD5"); byte[] result = md.digest(str.getBytes("utf-8")); return hexToString(result); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } return null;}public static String hexToString(byte[] b) { StringBuilder sb = new StringBuilder(); for (int i = 0; i < b.length; i++) { String hex = Integer.toHexString(b[i] & 0xFF); if (hex.length() == 1) { hex = '0' + hex; } sb.append(hex.toLowerCase()); } return sb.toString();} }
在eclipse中新建工程和包,图示如下
说明
可以在eclipse中实现查看加密结果是否正确
导出jar包
导出jar操作如图
将导出的jar放到Jmeter安装目录下的lib文件夹下
Jmeter新建测试计划,添加线程组,新建BeanShell Sampler,并写入以下测试内容
说明
之前已经在测试计划中添加了用户自定义变量,如图
所以这里直接在BeanShell Sampler中直接get已经设置的用户变量,方法是vars.get
,代码如下
//导入md5的jar包import com.test.mymd5;//定义机构代码String code = vars.get("customerCode");//定义时间戳String timestamp = vars.get("timestamp");//定义机构中的serial_number_md5,临时会话验证String ytoken = vars.get("ytoken");//定义英文下划线_ underscores String underscores = vars.get("underscores");//获取创建会话中的token验证的md5加密String itoken = mymd5.md5(code+timestamp+ytoken);//获取用户会话中的token验证的md5加密,存储为变量itokenvars.put("itoken",itoken);System.out.println(itoken);
这样时间戳和md5加密都实现了,接下来就是在接口中使用此变量。
在创建会话认证接口操作如下:
新建一个http请求和http请求默认值,在http请求默认值basic中配置接口的服务器名称或ip、请求的协议等参数如下图http请求默认值的作用就是在其他接口中,可以不用再次输入服务器名称或ip以及端口号等信息。
请求会话认证接口中,输入接口的元素项以及请求的post方法,而使用用户自定义的变量,可以使用${变量名}
直接使用该参数,如下
在测试计划中添加sampler-->Debug Sampler监听jmeter中的变量信息,配置如图
查看运行结果
在测试计划中添加监听器-->查看结果树,使用快捷键ctrl+R,查看运行结果,如图
而jmeter中变量的界面展示如图所示
以上操作即是获取时间戳和md5加密的方法。这样认证接口就不用每次单独计算timestamp和md5值。
遇到的问题
md5加密导出的jar包,引入过后运行时提示Unsupported major.minor version 52.0
,如图
究其原因,发现是jdk版本不一致造成的。解决方法如下:
1) 调整jdk版本一致:
eclipse>windows>preferences>java>compiler>compiler compliance level 1.8,如图修改jdk compliance版本为1.8的版本;
2) 项目右键>properties>java compiler>1.8
3) 添加jdk的lib
然后重新打包jar文件,再次导入jmeter中,成功
备注
The reported major numbers are:
Java SE 9 = 53,
Java SE 8 = 52,
Java SE 7 = 51,
Java SE 6.0 = 50,
Java SE 5.0 = 49,
JDK 1.4 = 48,
JDK 1.3 = 47,
JDK 1.2 = 46,
JDK 1.1 = 45
参考资料
md5的jar下载链接: 密码: cbb3