jmeter之beanshell的基本用法
一,官网:http://www.BeanShell.org/
二、Jmeter有哪些Bean Shell
-
定时器: BeanShell Timer
-
前置处理器:BeanShell PreProcessor
-
采样器: BeanShell Sampler
-
后置处理器:BeanShell PostProcessor
-
断言: BeanShell断言
-
监听器: BeanShell Listener
三、BeanShell的用法
在此介绍下BeanShell PreProcessor的用法,其它的beahshell可以类推。在此我们使用beahshell调用自己写的工具类,工具类实现了密码的加、解密功能:
1、在eclipse写好代码,然后把该类打成jar包(在类上点击右键->Export->jar file)jar包放到jmeter目录的\lib\ext下
如何使用idea2019打jar可参考这个文件https://blog.csdn.net/yueWang_blog/article/details/90718071
3、打开jmeter,添加一个http sampler,在sampler下添加一个BeanShell 取样器(如果jmeter已经打开了,步骤2中jar包要生效,必须才重启jmeter)
4、在beanshell 取样器中导入我们的jar包,调用里面的加、解密码方法,把结果保存在jmeter变量中,下面两个方法是beanshell中我们最常用到的:
- vars.get(String paramStr):获得变量值
- vars.put(String key,String value):,将数据存到jmeter变量中
四、Bean Shell常用内置变量
JMeter在它的BeanShell中内置了变量,用户可以通过这些变量与JMeter进行交互,其中主要的变量及其使用方法如下:
1.log:输出日志----如:log.info("hello jmeter"),会显示在jmeter的控制台
2,ctx:该变量引用了当前线程的上下文
import org.apache.jmeter.samplers.SampleResult;
SampleResult result = ctx.getPreviousResult();
log.info("=======result========="+result);
//getRequestHeaders()方法返回String字符串,获取请求头数据
String RequestHeaders = result.getRequestHeaders();
log.info("=======请求头========="+RequestHeaders);
//getResponseHeaders() 返回响应headers
String ResponseHeaders = result.getResponseHeaders();
log.info("=======响应头========="+RequestHeaders);
//getResponseCode() 返回http响应状态码字符串
String responseCode = result.getResponseCode();
log.info("=======响应状态码========="+responseCode);
//getURL() 返回请求URL对象
URL url = result.getURL();
log.info("=======请求URL========="+url);
3,prev - (SampleResult):获取前面的sample返回的信息,常用方法:
getResponseDataAsString():获取响应信息
getResponseCode() :获取响应code 这个和ctx中的String responseCode = result.getResponseCode();效果一样
我们在看看常用的方法
import org.json.*;(一定要找与Jmeter对应的json.jar放到ext目录下,否则会报找不到jar)
String response_data = prev.getResponseDataAsString();
JSONObject result = new JSONObject(response_data); //解析json串
log.info("======"+result);
//获取data整体内容,因为data的内容是json,所以要用getJSONObject
JSONObject data = result.getJSONObject("data");
log.info("===验证码==="+data);
//获取message内容,因为message是string,所以用getString
String mes = result.getString("message");
log.info("===message==="+mes);
//获取短信验证码的内容,把获取的内容可以用vars.put方法给jmeter用
String smscode = result.getJSONObject("data").getString("smsVerificationCode");
log.info("===message==="+smscode);
String response_code = prev.getResponseCode();
log.info("======"+response_code);
4,vars - (JMeterVariables):操作jmeter变量,这个变量实际引用了JMeter线程中的局部变量容器(本质上是Map),它是测试用例与BeanShell交互的桥梁,常用方法:
vars.get(String key):从jmeter中获得变量值
vars.put(String key,String value):数据存到jmeter变量中
5,props - (JMeterProperties - class java.util.Properties):操作jmeter属性,该变量引用了JMeter的配置信息,可以获取Jmeter的属性,它的使用方法与vars类似,但是只能put进去String类型的值,而不能是一个对象。对应于java.util.Properties
props.get("START.HMS"); 注:START.HMS为属性名,在文件jmeter.properties中定义
props.put("PROP1","1234");