在利用jmeter进行接口测试或者性能测试的时候,我们需要处理一些复杂的请求,此时就需要利用beanshell脚本了,BeanShell是一种完全符合Java语法规范的脚本语言,并且又拥有自己的一些语法和方法,所以它和java是可以无缝衔接的。beanshell由于内置了一些特有的变量,没法在一些集成代码工具上去调试。今天就和大家分享下常用的2个代码例子,大家可以直接拿来稍微修改下就可以使用。
Bean Shell内置变量大全
首先大家需要掌握bean shell本身自带的一些内置变量和一些方法。JMeter在其BeanShell中内置了变量,用户是通过这些变量与JMeter进行交互。
1.log 打印日志,写入信息到jmeber.log文件。
2.SampleResult 获取SampleResult对象,能通过这个对象获取想要的信息。
3.Response 获取Response对象,能通过这个对象获取响应信息。
4.Failure 查看接口调使用能否成功,假如返回false是成功的,true是失败的。
5.FailureMessage 失败信息,没有设置的时候失败信息是空的,能set这个信息。
6.ResponseData 获取response body类型是byte[]。
7.ResponseCode 返回接口code成功是200。
responseCode返回接口code成功是200;
8.ResponseMessage 获取msg成功是OK。
ResponseMessage获取msg成功是ok;
9.ResponseHeaders 获取接口服务端返回的头部信息。
ResponseHeaders获取接口服务端返回的头部信息。
10.RequestHeaders 获取用户端请求的头部信息。RequestHeaders 获取用户端请求的头部信息
11.SampleLabel 获取接口请求的名称。 SampleLabel获取接口请求的名称
12.SamplerData 获取请求的url和body。 SamplerData获取请求的url和body
13.ctx 代表上下文信息,能直接用。 ctx代表上下文信息,能直接用
14.vars即JMeterVariables,操作jmeter变量,这个变量实际引用了JMeter线程中的局部变量容器(本质上是Map),常用方法:
a) vars.get(String key):从jmeter中获得变量值;
b) vars.put(String key,String value):数据存到jmeter变量中;
15.prev 获取前面的sample返回的信息,常用方法:
a) getResponseDataAsString():获取响应信息。
b) getResponseCode() :获取响应code。
实例:
签名函数
import java.util.*;
import Sign.*;
Signature signs = new Signature();
String appid = vars.get("login_appid");
String openid = vars.get("openid");
log.info(openid);
Map headers = signs.make_headers(appid);
Map url_params = new HashMap();
url_params.put("appId", appid);
url_params.put("openId", openid);
log.info(String.valueOf(headers));
String url ="https://" +vars.get("login_url")+vars.get("login_params");
log.info(url);
headers = signs.get_signature(url, "GET", url_params, headers);
log.info(String.valueOf(headers));
vars.put("h_appid", headers.get("X-QP-AppId"));
vars.put("h_timestamp", headers.get("X-QP-Timestamp"));
vars.put("h_nonce", headers.get("X-QP-Nonce"));
vars.put("h_signature", headers.get("X-QP-Signature"));