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的主要内容,如果未能解决你的问题,请参考以下文章

jmeter操作beanshell脚本 -- 11

jmeter(四十五)常用Beanshell脚本

Jmeter - BeanShell常用内置变量及脚本开发

Jmeter常用脚本开发之Beanshell Sampler

JMeter BeanShell示例

JMeter基础 — JMeter中BeanShell断言详解