背景及思路:
需求:要做 创建新卡 接口的测试,要求:
1. 不需要每次手动修改请求参数。
方案:文中先用excle将数据准备好,导出为csv格式,再用jmeter的csv请求进行参数化
2. 卡号需要唯一;
方案:文中用jmeter的beanshell按时间戳加随机数生成
3. 请求参数中有一个参数,会根据相应的请求参数生成(文中的sign值),接口请求会验证sign是否和相应请求参数对应;
方案:
1. 文中将生成sign的源码打包放在jmeter的lib\ext\ 下,
2. 再用jmeter的beanshell引用jar包,
3. 用同样的规则生成sign保证其一致性。
-----下面正式开始实战------:
-
将生成验签的java源码生成jar包,并将jar包放置在 \lib\ext目录下
1.1 将生成sign规则的java类 打jar包 包路径:com.util.lt
1.png
1.2 选择JAR file
2.png
1.3 放置在jmeter的 lib\ext\下面 取名为 AppLoginUtils
3.png
1.4 如果对路径不熟悉的话,可以将刚刚生成的jar包放在D盘, 解压,查看目录路径
4.png
进 META-INF
5.png
-----至此---java生成jar包并放在jmeter相应目录准备工作做好了.-----
-
参数化 excle 准备数据
2.1 excle 列出个参数及值
6.png
2.2 另存为csv格式
7.png
2.3 用文本编辑器(如:editplus)打开文本,第一行为参数名,下面为参数,剪切第一行数据为jmeter csv参数行,实际数据去掉第一行数据
8.png
-------------至此----测试参数准备好了.----------------
-
jmeter 开始进行测试 添加线程组
9.png
3.1 jmeter设置csv参数 variableNames行数据为上面剪切的第一行数据
10.png
11.png
3.2 BeanShell PreProcessor 添加脚本生成需要的信息字段(生成cardNo为时间戳唯一数 为后续生成sign做准备)
12.png
13.png
脚本如下:
<pre>
import java.sql.Date;
import java.text.SimpleDateFormat;
Long timeStamp = System.currentTimeMillis(); //获取当前时间戳
SimpleDateFormat sdf = new SimpleDateFormat("yyMMddHHmmss"); //定义时间格式
String timeNow = sdf.format(new Date(timeStamp)); // 时间戳转换成定义好的时间格式
//(数据类型)(最小值+Math.random()(最大值-最小值+1))
//从1到9999的int型随机数
String cardNo = timeNow + (int)(1+Math.random()(9999-1+1));
//vars.get("name"); 从jmeter中获得变量值
//vars.put("key","value"); 数据存到jmeter变量中
vars.put("cardNo",cardNo); //将生成的当前时间加随机数生成的唯一字符串保存到jemter变量cardNo中
log.info("------------日志开始----------------");
log.info("cardNo is:"+cardNo);
log.info("------------日志结束----------------");
</pre>
3.3 BeanShell PreProcessor 调用jar包的方法 生成sign值
同上添加 BeanShell PreProcessor 步骤,
12.png
111.png
脚本如下:
<pre>
import java.util.*;
import com.util.lt.AppLoginUtils;
public static getSign(String cardNo){
Map paras = new HashMap();
//取出刚刚csv参数化的数据,放到map中
paras.put("sex",vars.get("sex"));
paras.put("xxx", vars.get("xxx"));
paras.put("xxxx", vars.get("xxxx"));
paras.put("xxxxx", vars.get("xxxxx"));
paras.put("type",vars.get("type"));
paras.put("operator", vars.get("operator"));
paras.put("cardNo",cardNo); //传参
paras.put("codeName", vars.get("codeName"));
paras.put("operatorName", vars.get("operatorName"));
paras.put("xxxxxx", vars.get("xxxxxx"));
//调用 上面java打包的 生成验签码的方法
String sign = AppLoginUtils.getParametersToString(paras,"xxxxxxxxxxxxxxxxxxxxxxx");
vars.put("sign",sign); //将生成的sign存到jmeter变量sign中,供后续请求用
return sign;
}
//vars.get("name"); 从jmeter中获得变量值
//vars.put("key","value"); 数据存到jmeter变量中
log.info("------------日志开始----------------");
//下面供调试使用 使用上面 beanshell生成的 cardNo作为请求参数 以此保证使用的是一套数据
log.info("sign is:"+ getSign("${cardNo}"));
log.info("------------日志结束----------------");
</pre>
3.4 http请求 输入相应的地址 端口号 路径 编码格式
14.png
3.4.1 parameters请求信息形式:
15.png
3.4.2 或者用 bodydata请求信息形式(与上面的请求形式二选一 其中一个可以右键--禁用):
16.png
3.5 添加 debug sample 进行测试调试用 (可不用添加)
17.png
3.6 添加监控器 查看结果树 聚合报告:
18.png
3.6.1监测的请求:
19.png
20.png
3.6.2 监测的返回:
21.png
3.6.3 监测的 debug Sample:
22.png
23.png
-------至此----一个完整的调用和监控结束了.-------
接下来是 在做的过程中的一些注意点:
一. 怎么调试:
1.可以用beanShellSample 进行请求,debugSample 在查看结果树中 进行调试 。
2.也可以打印日志 log.info() 进行调试,需要先打开查看日志的选项:
24.png
二. 编码问题:
jmeter乱码 修改jmeter\bin\jmeter.properties文件:
-
把“jsyntaxtextarea.font.family=Hack”这行的“#”注释去掉 或者添加一行 用中文字体都行
25.png -
sampleresult.default.encoding="utf-8"
26.png -
参数化的话 文件另存为utf-8 的话 ,编码需要 utf-8,系统默认的话就不用
27.png
28.png -
http请求的 content encoding:utf-8
29.png -
生成加密的java源码的方法中指定请求编码类型: s.getBytes("utf-8")
30.png
网友评论