jmeter 小脚本 BeanShell PreProcessor vars.get
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jmeter 小脚本 BeanShell PreProcessor vars.get相关的知识,希望对你有一定的参考价值。
参考技术A 可以用jmeter写一些小脚本。背景:测试一个职位需要投递20个人投递,比较麻烦,不想手工投递,就来偷个懒
思路:用CSV参数化用户,获取用户的cookie,再去投递就OK。
历程:
1、HTTP Cookie 管理器,我所知道的用法就是直接加这个主件就行了,但是,重来没好用过,pass
2、信息头里,放cookie,信息头放在请求下。
这里写成cookie,就OK,但是请求头里,是看不到cookie的,
这里写成cookies,但是请求头看得到cookie,但是请求就不通。
方法1:
骚操作:
用正则表达式获取cookie,因为是2个cookie要拼接。就直接在信息头里写的,结果居然可以,但是已投递的,返回的结果是对的,没有投递的简历,返回结果是“该简历已删除,无法投递”,但是我的简历没有删除,后来问了开发,中间差了个选择简历的接口。
想把cookie打印出来看看,debug sample看不到,写到BeanShell PostProcessor ,直接打印cookie,打印出来的是null
把这个cookie再放在一个用户自定义变量,打印出来,就是【AAA_XSESSION_ID="$chy_token";AAA_XSESSION_ID_EXP="$EXP"】
方法2:写个小脚本,舍近求远
结果:纵使觉得天衣无缝,结果请求还是不成功,就当练手了。
脚本里来打印cookie,看看对不对,再把这个cookie返回给jmeter外部用,就是vars.get。vars.put
vars.get:jmeter中定义的变量,拿进来还需要再定义一次。
vars.put:beanshell里定义的变量,拿出去在jmeter中用,就要put出去。
log.info:打印
拼接字符串:用+,字符串中有引号的,单引号,双引号套用。
每句话结尾记得打分号;
具体格式如下:
import org.json.*;
import java.lang.Integer;
import java.lang.String;
import java.lang.Math;
EXP= vars.get("EXP");
chy_token= vars.get("chy_token");
//拼接字符串
String cookie="AAA_XSESSION_ID="+'"'+EXP+";"+"AAA_XSESSION_ID_EXP="+'"'+chy_token;
vars.put("cookie",cookie);
log.info(cookie);
Jmeter之BeanShell脚本
学了Java的一些基本语法后,就可以来在Jmeter中写写BeanShell脚本了。
直接在线程组下创建一个BeanShell取样器,然后在脚本区写java代码:
写了个循环,执行后在这里看不到,要在jmeter.bat的windows批处理里看到:
JMeter在它的BeanShell中内置了变量,用户可以通过这些变量与JMeter进行交互:
1、log:写入信息到jmeter.log文件,使用方法:log.info(“hahahahahahah”);
2、vars:操作jmeter变量,这个变量实际引用了JMeter线程中的局部变量容器(本质上是Map),它是测试用例与BeanShell交互的桥梁,常用方法:
a) vars.get(String key):从jmeter中获得变量值
b) vars.put(String key,String value):数据存到jmeter变量中
添加日志查看:
使用vars:
在线程组2里面去访问vars变量,输出null,可见vars确实是个局部变量:
3、props:操作jmeter属性,该变量引用了JMeter的配置信息,可以获取Jmeter的属性,它的使用方法与vars类似,但是只能put进去String类型的值,而不能是一个对象。对应于java.util.Properties。
props的全局性:
4、prev:获取前面的sample返回的信息,常用方法:
a)getResponseDataAsString(): 获取响应信息;
b) getResponseCode(): 获取响应代码;
先发个接口请求,然后prev获取返回信息:
自定义函数:使用Java自定义函数来处理特定的逻辑,结合BeanShell的内置对象进行变量的存取,提高脚本的灵活性。
写了个自定义的静态函数,实现的是整数的累加:
发现报错,原来是函数的返回值是int类型的,而log.info()里面要的是String。这里把int类型的result转换为string有三种方法:
1、String.valueOf(result)
2、Integer.toString(result)
3、result+""
任选一个即可。
引用外部java文件:在BeanShell中通过source("代码路径")方法引入Java文件,然后调用方法和java一样,new一个对象,通过
对象调用里面的方法。
写个静态方法,保存为Test.java文件,放在D盘下:
然后在BeanShell里引用Test.java,调用函数,传参100,日志输出:
引用外部jar包
首先打包:
1、把当前的Test作为运行文件,先运行一遍。
2、右键项目名--Export--Runnable JAR file.
3、在Launch找到运行文件,放到jmeter安装目录下lib/ext下。
4、在Jmeter的BeanShell里导包,调用方法。
这里我运行报错了,说方法找不到,摸索良久后尝试在测试计划里添加一下jar包,结果成功了。
以上是关于jmeter 小脚本 BeanShell PreProcessor vars.get的主要内容,如果未能解决你的问题,请参考以下文章