Jmeter Beanshell 高阶使用

1、 Beanshell 的介绍

  • Beanshell主要分为:
    - 1、 BeanShell PreProcessor 【重要】
    - 2、BeanShell PostProcessor 【重要】
    - 3、BeanShell Assertion 【重要】
    - 4、BeanShell Timer
    - 5、BeanShell Listener 【重要】

2、Beanshell 的使用

	 - 单线程中读取变量和使用变量
// 获取变量
String hotelSystemConnectionId = vars.get("hotelSystemConnectionId");

// 存储变量
vars.get("hotelSystemConnectionId",hotelSystemConnectionId); // 格式为:vars.get("变自定义变量名",值)

// 值得注意的是:vars.get只能存储string的值,如果是object对象需要使用另外的方法
'''
目前已知的是只能存储:List、Map
jsonobject好像都不行
'''
// 存储变量
vars.putObject("hotelSystemConnectionId", Object);
// 获取变量
vars.getObject("hotelSystemConnectionId");
	 - 多线程中读取变量和使用变量
props.get("hotelSystemConnectionId");
props.get("hotelSystemConnectionId",hotelSystemConnectionId);
props.putObject("hotelSystemConnectionId", Object);
props.getObject("hotelSystemConnectionId");

vars和props的区别就是props可以跨线程组使用,并且props返回的是Hashtable对象
	 -  线程中打印日志
	 	在windows用界面右上角可以点击查看到打印的日志
	 	如果是在Linux上,那么运行完成后,查看jmeter.log可以看到该日志
// 打印任意日志:
log.info("hotelSystemConnectionId:" + hotelSystemConnectionId);

// 有时候,你并不像打印info级别的日志,可以在jmeter的bin目录下编辑jmeter.properties文件,修改log等级为error
'''
操作步骤:
1、jmeter的bin目录下编辑jmeter.properties文件,其中将#jmeter.loggerpanel.display=false
	解注释并修改为true [jmeter.loggerpanel.display=true]
2、修改jmeter的bin目录下编辑log4j2.xml文件,搜索level,然后修改成对应的error级别

//打印error级别的日志
log.error("anything");

// 如果想在cmd显示日志,可以使用
print("anything");
'''
-----------------------------  请求 ----------------------------
// 获取到请求的boby (实际上会同时返回url,和请求boby)
log.info("获取到请求的boby:",prev.getSamplerData());
// 获取请求的url
log.info("获取请求的url:"+prev.getUrlAsString());
----------------------------- 响应 ----------------------------
// 获取响应结果
log.info("获取响应结果:"+prev.getResponseDataAsString()); 
log.info("获取响应结果: " + prev.getResponseMessage()); // 这个不是string类型的
// 获取响应code (需要用int接收)
log.info("获取响应code:",prev.getResponseCode());
// 获取响应headers
log.info("获取响应headers:",prev.getRequestHeaders());
// 获取响应Body大小
prev.getBodySizeAsLong(); 
----------------------------- 解决乱码 ----------------------------
prev.setDataEncoding("utf-8");

重磅代码(场景是我需要记录接口响应的时间),
注意这段代码不能使用BeanShell PreProcessor ,
想你也知道啊,ResponseHeaders你在请求前你也拿不到啊 是不是

String backtim = prev.getResponseHeaders();
String a= backtim.substring(backtim.indexOf("Fri")+4,backtim.indexOf("GMT")+3);  //每天都要变
Date date = null;
log.info("~~~~~~~"+c);
try {
	date = new SimpleDateFormat(" d MMM yyyy K:m:s z",Locale.ENGLISH).parse(a);
 } 
catch (ParseException e) {
 // TODO Auto-generated catch block
 	e.printStackTrace();
 }
SimpleDateFormat sf2 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String ti = sf2.format(date);
log.info(ti);
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值