当前位置:   article > 正文

jmeter 使用beanshell 编写脚本

beanshell

目录

一、介绍

1.1 介绍

1.2 下载&启动

 二、jmeter中创建beanshell脚本

三、jmeter与beanshell 数据交互

3.1 例子1 beanshell 将变量传给jmeter

3.2 例子二  jmeter 接收beanshell 生成的变量

四、jmeter中Beanshell 调用 java 代码

4.1 调用java文件

4.2  beanshell调用外部 jar 包

五、beanshell 打印日志

5.1 log日志打印

5.2 打印变量

六、变量

6.1 vars

6.2 props

6.3 prov

6.4 ctx上下文

七、线程组1生成的动态变量给线程组2用

7.1 背景:

7.2 独立运行线程组:

7.3 解决思路及方案

思路:

方案一:使用beanshell 

方案二:使用函数助手

八、prev 获取前面的sample返回的信息,再做处理

8.1 设置上一个sample 的响应结果的编码

九、beanshell应用

9.1 验签处理&加密


一、介绍

1.1 介绍

BeanShell是一个小型的、免费的、可嵌入使用Java编写的具有对象脚本语言特性的Java源码解释器。

BeanShell是一种完全符合Java语法规则的脚本语言,同时他还有自己的语法规则。

动态执行所有Java语句、Java代码片段以及弱类型Java和附加的脚本的便利
透明地访问所有Java对象和API
四种运行模式:命令行、控制台、Applet、远程会话服务
可以在受安全限制的环境下工作,不需要类加载器或者绝大多数功能的字节码生成器
程序只有大约150K的Jar文件
纯Java
免费
 

编写baanshell脚本,使用的语言,几乎跟java一模一样。

1.2 下载&启动

下载:

BeanShell下载地址是:www.beanshell.org

 下载下来是一个jar包,bsh-2.0b4.jar

启动:

启动有四种方式,我只用一种方式,其他的可以去百度一下。

在终端中,执行命令

 java -jar bsh-2.0b4.jar

 二、jmeter中创建beanshell脚本

 线程组--》添加--》取样器/sampler --》 BeanShell 取样器

 脚本文件:我们可以直接引入写好的脚本

脚本:我们自己在jmeter中手写脚本的地方。

三、jmeter与beanshell 数据交互

jmeter与beanshell 数据交互,是通过函数实现的。

vars(JMeterVariables) : 操作jmeter 变量,常用方法:

vars.get(String key) : 从jmeter中获得变量值

vars.put(String key,String value): 将数据存到jmeter变量中。

-------小技巧---------------------

我们可以先在idea中,编写beanshell脚本,写完之后,再复制到jmeter中。(因为jmeter 编写脚本时,不方便,没有错误提示等功能)

3.1 例子1 beanshell 将变量传给jmeter

beanshell 脚本:

  1. a= 1;
  2. b=4;
  3. q = a+b;
  4. vars.put("q",q+"")

运行,然后去结果树中,查看日志。

 注意:

在脚本中,put q时,为啥要+“” ?

因为put函数,key 与value 都要求是String格式的,但是在我们的这个脚本中,得到的q的值是

int类型的,所以要先转成String再put。(int+Sttring=String)

vars.put(String key,String value):

3.2 例子二  jmeter 接收beanshell 生成的变量

背景:

一个接口请求,传参,要求传当前的时间,且格式为 yyyy-MM-dd HH:mm:ss 

处理方案:

beanshell 脚本,将当前时间,格式化为  yyyy-MM-dd HH:mm:ss 格式,然后将值传给jmeter

整个jmeter 脚本结构

beanshell脚本编写:

  1. import java.text.*;
  2. import java.util.*;
  3. DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  4. Date d = new Date();
  5. String dateStr = df.format(d);
  6. vars.put("current_date",dateStr);

HTTP 请求,接收参数,current_date

${current_date}

运行jmeter脚本,查看结果树。

 变量引用成功。

四、jmeter中Beanshell 调用 java 代码

4.1 调用java文件

语法:

source(" java 文件路径") 其中文件路径可以使用绝对路径,也可以使用相对路径。

source("E:\eclipse\workspace\MD5\src\jmeter\MD5.java"); 或者: source("MD5.java"); --文件位于 jmeter bin 目录下

String strMd5 = MD5.GetMD5Code("123456");

举例:

1、我自定义了一个类CsDIY.java

  1. package bingfa;
  2. import java.text.*;
  3. import java.util.*;
  4. public class CsDIY {
  5. public String getCurrentDate(){
  6. DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  7. Date d = new Date();
  8. String dateStr = df.format(d);
  9. return dateStr;
  10. }
  11. }

然后将CsDIY.java 放置在了我电脑桌面上。

2、Beanshell脚本,引用CsDIY.java这个类,并调用其中方法

  1. source("/Users/zhaohui/Desktop/CsDIY.java");
  2. CsDIY cs = new CsDIY();
  3. String dateSSS = cs.getCurrentDate();
  4. vars.put("dateSSS",dateSSS)

3、接口请求,使用变量

4.2  beanshell调用外部 jar 包

1、提前把 jar 包放入 jmeter lib\ext 目录下并重启;

2、在jmeter 线程组下,添加http sampler->BeanShell Sampler

3、在beasnshell 中的头文件,导入该jar包

import 类名;

示例:

import com.MD5;

String strMd5 = MD5.GetMD5Code("123456");

五、beanshell 打印日志

5.1 log日志打印

log: 写入信息到jmeter.log文件中。

log输出4个级别与使用方法:

  1. log.debug("我是日志1---------");
  2. log.info("我是日志2---------");
  3. log.warn("我是日志3---------");
  4. log.error("我是日志4---------");

查看打印的日志:

方法一:Jmeter日志默认存放在%JMeter_HOME%\bil\JMeter.log

方法二:JMeter里面点击右上角可以打开日志窗口

5.2 打印变量

log.info(“abc”)——输出常量
log.info(name);——输出beanshell定义的变量
log.info(${name});——输出Jmeter定义的变量

六、变量

6.1 vars

vars表示:JmeterVariables,操作Jmeter变量(只能在当前线程组使用)

  1. 用户定义的变量
  2. 正则表达式,JSON提取器。
  3. 定义变量
  1. //获取变量的值
  2. log.info(vars.get("hhh"));
  3. log.info(vars.get("access_token"));
  4. vars.put("www","yyy");

6.2 props

props用于存取Jmeter的全局静态变量(可以跨线程组)

  1. //获取全局静态变量
  2. log.info(props.get("jmeter.save.saveservice.output_format"));
  3. props.put("aaa","bbb");

6.3 prov

prov获取到当前一个取样器返回的信息

  1. //获取前面取样器的值
  2. log.info(prev.getResponseCode());
  3. log.info(prev.getResponseDataAsString());

6.4 ctx上下文

  1. //获取上下文所有的变量
  2. System.out.println(ctx.getProperties());

七、线程组1生成的动态变量给线程组2用

7.1 背景:

测试计划下,两个线程组,线程组1和线程组2。 需要将线程组1 beanshell 脚本产生的变量,给线程组2 用。

7.2 独立运行线程组:

当运行测试计划时,线程组1与线程组2是同时运行的。我们需要先运行线程组1,再运行线程组2,为了保证线程组运行顺序,我们需要在测试计划中,勾选独立运行线程组。

7.3 解决思路及方案

思路:

1、线程组1生成变量时,将变量设置为全局变量。

props.put("xx",xxx);

2、线程组2,取变量时,取这个全局变量

props.get("xx")

方案一:使用beanshell 

在线程组2中,写一个beanshell  脚本,使用props.get("xx") 去取变量

线程组1

  1. a=1;
  2. b=3;
  3. c=a+b;
  4. props.put("c",c+"");

线程组2

  1. d=props.get("c");
  2. log.info(d+"-------------");

方案二:使用函数助手

工具--函数助手--BeanShell

在表达式中,填写 props.get("xx")

然后点击生成

再在线程组2中,直接使用${__BeanShell(props.get("dateSSS"),)}

线程组2

  1. d=${__BeanShell(props.get("c"),)};
  2. log.info(d+"-------------");

 

八、prev 获取前面的sample返回的信息,再做处理

getResponseDataAsString():获取响应信息

getResponseCode(): 获取响应信息

setDataEncoding(String dataEncoding): 设置响应结果的编码

8.1 设置上一个sample 的响应结果的编码

举例:

背景:

jmeter脚本结构:

 对 www.baidu.com ,发出请求,查看返回结果:

发现结果树中,中文都是乱码的。

解决办法:

修改返回结果的编码。

1、在该线程组中,加一个BeanShell 取样器(添加--》取样器--〉 BeanShell 取样器)

 2、 BeanShell 取样器 中编写脚本

prev.setDataEncoding("utf-8");

3、将 BeanShell 取样器 放置在被测http请求的后面。(注意放置位置)

 再次进行请求,结果树中的响应结果,就不会再乱码了。

九、beanshell应用

BeanShell PreProcessor

提前处理请求参数,如:图片处理,加密解密等

BeanShell PostProcessor

在请求后对返回结果进行处理

BeanShell 断言

验证返回结果的正确性

BeanShell Sampler

9.1 验签处理&加密

jmeter脚本处理加密验签_做测试的喵酱的博客-CSDN博客

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小桥流水78/article/detail/1014293
推荐阅读
相关标签
  

闽ICP备14008679号