jmeter之仅一次控制器、If控制器、前置处理器beanshell、后置处理器beanshell

1、仅一次控制器

作用是把请求放到仅一次里面的时候,不管循环数写几次,放到仅一次控制器里的请求都只跑一次,大部分用在登录,一般就登录一次就可以了,还有jdbc连接 也是连接一次就可以了,不用重复连接。

2、If控制器

如果(If)控制器,if控制器如果里面的条件不满足,是不执行里面的请求的,看用户自定义变量里的定义的methodName 的值是 
"${methodName}".equals("post")
${__BeanShell(vars.get("run").equals("1"))}
3.0以后版本用beanshell 中vars.put(“run”,“f”); debugsample 响应数据中看不到输出值。

3、前置处理器

与后置处理器一样

4、后置处理器

在bean shell中通过source("代码路径")方法引入java,然后调用方法和java一样,new一个class,再调用里面的add 方法。
4.1log:写入信息到jmeber.log文件,使用方法:log.info(“This is log info!”);


4.2ctx:该变量引用了当前线程的上下文,几乎不用


4.3vars - (JMeterVariables):操作jmeter变量,这个变量实际引用了JMeter线程中的局部变量容器(本质上是Map),它是测试用例与BeanShell交互的桥梁,常用方法: 最常用的一个
a) vars.get(String key):从jmeter中获得变量值
b) vars.put(String key,String value):数据存到jmeter变量中
beanshell 里面定义的值,引用比在用户自定义里面引用级别高 验证一下


4.4 props - (JMeterProperties - class java.util.Properties):操作jmeter属性,该变量引用了JMeter的配置信息,可以获取Jmeter的属性,它的使用方法与vars类似,但是只能put进去String类型的值,而不能是一个对象。对应于java.util.Properties。  作用不是很大
a) props.get("START.HMS");  注:START.HMS为属性名,在文件jmeter.properties中定义 
b) props.put("PROP1","1234")


4.5 prev - (SampleResult):获取前面的sample返回的信息,常用方法:
getResponseDataAsString():获取响应信息
getResponseCode() :获取响应code
prev.setResponseCode("798");
prev.setSuccessful(false);
prev.setResponseMessage("预期结果和实际结果不同");
prev.setResponseData("123312123");
sampler - (Sampler):gives access to the current sampler

List results = vars.getObject("resultList");
//把结果遍历
for(Object o : results){
	//遍历结果强制转成map              
	Map map = (Map)o;
	//用map里的keySet 遍历 ,get 取值
	for (Object k : map.keySet()){
		log.info(k+":"+map.get(k));
	}
}
String enconding = vars.get("ip");
log.info("enconding:::::::::::"+enconding);
vars.put("run","f");

String output_format = props.get("jmeter.save.saveservice.output_format");
log.info("output_format::::"+output_format);


String responseData = prev.getResponseDataAsString();
String code = prev.getResponseCode();
log.info("responseData:::::"+responseData);
log.info("code:::::::"+code);

//源码里定义的code是String,状态码自定义 数字,结果可以在后置处理器人为干预
//prev.setResponseCode("798");
//prev.setSuccessful(false);
//prev.setResponseMessage("预期结果和实际结果不一致");
//setResponseData("122222222222");
//正在表达式里的值,跟顺序有关系, 正则提取的在上面,里面的引用名称,取他的值做校验用
log.info("myname::::::"+vars.get("myname"));










评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

NeilNiu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值