JMeter在它的BeanShell中内置了变量,用户可以通过这些变量与JMeter进行交互,其中主要的变量及其使用方法如下:
1、vars:这个变量实际引用了JMeter线程中的局部变量容器(本质上是Map),因此可以通过put和get方法访问JMeter中的变量。这个变量是所有内置变量中最有用的,它是测试用例与BeanShell交互的桥梁。对应于org.apache.jmeter.threads.JMeterVariables
a) vars.get(String key):从jmeter中获得变量值
b) vars.put(String key,String value):数据存到jmeter变量中
如果需要获取或者放置非String类型数据 需要用putObject()和getObject()
//Beanshell vars.putObject() vars.getObject()的使用
List list = new ArrayList();
list.add("aaa");
list.add("bbb");
//putObject()可以在vars对象中放置Object类型对象
vars.putObject("list",list);
//===========================
//获取Object list对象
Object Value = vars.getObject("list");
//log.info只能输出String类型变量
log.info(Value.toString());
2、props:该变量引用了JMeter的配置信息,它的使用方法与vars类似,但是只能put进去String类型的值,而不能是一个对象。对应于java.util.Properties。
a) props.get("属性名"); 注:属性名,在文件jmeter.properties中定义
b) props.put("PROP1","1234");
3、prev:获取前面的sample返回的信息,常用方法:
a) getResponseDataAsString():获取响应信息
b) getResponseCode() :获取响应code
4、ctx:该变量引用了当前线程的上下文,理论上通过这个东西我们几乎可以控制当前线程相关的一切,不过这要求使用者非常熟悉JMeter的源码。对应于org.apache.jmeter.threads.JMeterContext。
cxt内置对象getPreviousResult()方法 调用请求/响应数据
//SampleResult需要import对象
import org.apache.jmeter.samplers.SampleResult;
SampleResult result = ctx.getPreviousResult();
//getRequestHeaders()方法返回String字符串
String RequestHeaders = result.getRequestHeaders();
//getResponseHeaders() 返回响应headers
String ResponseHeaders = result.getResponseHeaders()
//getResponseCode() 返回响应状态码字符串
String responseCode = result.getResponseCode();
//getURL() 返回请求URL对象
URL url = result.getURL();
log.info(RequestHeaders);
log.info(RequestHeaders);
5、sampler
使用时,需要引入包import org.apache.jmeter.config.Arguments;
a)获取http请求的 url
String url = sampler.getPath();
b)获取http请求的body内容
Arguments arguments = sampler.getArguments();
String body = arguments.getArgument(0).getValue();
6.SampleResult 获取SampleResult对象,能通过这个对象获取想要的信息。
7.Response 获取Response对象,能通过这个对象获取响应信息。
8.Failure 查看接口调使用能否成功,假如返回false是成功的,true是失败的。
9.FailureMessage 失败信息,没有设置的时候失败信息是空的,能set这个信息。
10.ResponseData 获取response body类型是byte[]。
11.ResponseCode 返回接口code成功是200。
12.ResponseMessage 获取msg成功是OK。
13.ResponseHeaders 获取接口服务端返回的头部信息。
14.RequestHeaders 获取用户端请求的头部信息。
15.SampleLabel 获取接口请求的名称。
16.SamplerData 获取请求的url和body。
例子1
使用jmeter的bean shell preprocessor,调用自己写的工具类,实现请求的处理。
步骤如下:
1、 用eclipse把自己写的java代码打包成jar。
2、 把自定义的JAR包放入到jmeter的/lib/ext目录下。
3、 重启jmeter,开始写beanshell脚本。
import net.sf.json.JSONObject;
import ht.test.PluginTest.*;
//请求体,mac做了参数化
String body1 = "{\"ID\":123456,\"RPCMethod\":\"BootInitiation\",\"PROTVersion\":\"1.0.0\",\"MAC\":\"${MAC}\"}";
int bodylenth1 = body1.length();
byte[] lenBytePrefix1 = utils.getBytesOfBig(bodylenth1);
//System.out.println(utils.bytesToHexString(lenBytePrefix2));
//System.out.println(utils.bytesToHexString(body2.getBytes()));
String postdata2 = utils.bytesToHexString(lenBytePrefix1) +
utils.bytesToHexString(body1.getBytes());
String postdata3 = postdata2.replaceAll(" ", "");
//System.out.println("binary data is :" + postdata3);
vars.put("postrequest",postdata3);
//System.out.println(vars.get("postrequest"));
例子2
使用beanshell的assertion断言,完成一些响应结果判断的的操作。
一个比较完整的代码框架如下。
import org.apache.jmeter.assertions;
import org.apache.jmeter.samplers.SampleResult;
import org.apache.jmeter.assertions.AssertionResult;
import org.json.*;
String response_data = prev.getResponseDataAsString();//获取接口返回的response数据
JSONObject data_obj = new JSONObject(response_data);//转换成json
//判断code是否等于0 如果等于0 再取里面的字段
String code = data_obj.get(“code”);
if(code.equals(“0”))
{
String user_name = data_obj.get(“data”).get(“user”).get(“userName”).toString();
//这里的my_name 是用户自定义的变量或者之前的接口返回获取的
if(user_name.equals(${my_name})){
Failure = false; //设置成false 表示接口跑成功,在结果树中sample是绿色的
//做后续动作
…….
}
else{
//做其他动作
}
}
else
{
Failure = true;//直接判断失败,表示接口跑失败,在结果树中sample是红色的
prev.setStopThread(true);//如果断言失败,后面的接口不需要再跑,直接暂停
}
技巧
高级用法:假如我们希望线程之间共享一个变量,可以利用BeanShell来完成。
JMeter中线程间共享变量可以通过定义属性值来完成,JMeter启动时会读取一些属性文件,比如jmeter.properties、user.properties,这些属性值是可以修改的,通过BeanShell可以对其进行更改。通过props.put()来修改属性,props.get()来获取属性。
原文链接:
https://blog.csdn.net/hujyhfwfh2/article/details/80862134
http://blog.51cto.com/14010723/2298911