• beanshell脚本常用的脚本


    在利用jmeter进行接口测试或者性能测试的时候,我们需要处理一些复杂的请求,此时就需要利用beanshell脚本了,BeanShell是一种完全符合Java语法规范的脚本语言,并且又拥有自己的一些语法和方法,所以它和java是可以无缝衔接的。beanshell由于内置了一些特有的变量,没法在一些集成代码工具上去调试。今天就和大家分享下常用的2个代码例子,大家可以直接拿来稍微修改下就可以使用。

    Bean Shell内置变量大全

    首先大家需要掌握bean shell本身自带的一些内置变量和一些方法。JMeter在其BeanShell中内置了变量,用户是通过这些变量与JMeter进行交互。 

    1.log 打印日志,写入信息到jmeber.log文件。

    2.SampleResult 获取SampleResult对象,能通过这个对象获取想要的信息。

    3.Response 获取Response对象,能通过这个对象获取响应信息。

    4.Failure 查看接口调使用能否成功,假如返回false是成功的,true是失败的。

    5.FailureMessage 失败信息,没有设置的时候失败信息是空的,能set这个信息。

    6.ResponseData 获取response body类型是byte[]。

    7.ResponseCode 返回接口code成功是200。

    8.ResponseMessage 获取msg成功是OK。

    9.ResponseHeaders 获取接口服务端返回的头部信息。

    10.RequestHeaders 获取用户端请求的头部信息。

    11.SampleLabel 获取接口请求的名称。

    12.SamplerData 获取请求的url和body。

    13.ctx 代表上下文信息,能直接用。

    14.vars即JMeterVariables,操作jmeter变量,这个变量实际引用了JMeter线程中的局部变量容器(本质上是Map),常用方法:

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

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

    15.prev 获取前面的sample返回的信息,常用方法:

    a) getResponseDataAsString():获取响应信息。

    b) getResponseCode() :获取响应code。

    在写代码的时候,可以直接用上面的变量和方法,参考如下例子。

    例子1

    使用jmeter的bean shell preprocessor,调用自己写的工具类,实现请求的处理。

    步骤如下:

    1、 用eclipse把自己写的java代码打包成jar。

    2、 把自定义的JAR包放入到jmeter的/lib/ext目录下。

    3、 重启jmeter,开始写beanshell脚本。

    具体代码:

    import net.sf.json.JSONObject;
    import ht.test.PluginTest.*;


             //请求体,mac做了参数化

           String body1 = "{"ID":123456,"RPCMethod":"BootInitiation","PROTVersion":"1.0.0","MAC":"${MAC}"}";


            int bodylenth1 = body1.length();
            byte[] lenBytePrefix1 = utils.getBytesOfBig(bodylenth1);
            //System.out.println(utils.bytesToHexString(lenBytePrefix2));

            //System.out.println(utils.bytesToHexString(body2.getBytes()));
            String postdata2 = utils.bytesToHexString(lenBytePrefix1) +
                           utils.bytesToHexString(body1.getBytes());

            String postdata3 = postdata2.replaceAll(" ", "");
            //System.out.println("binary data is :" + postdata3);

            vars.put("postrequest",postdata3);
            //System.out.println(vars.get("postrequest"));

    注意:在用system.out.println调试完成后,最终需要注射掉,否则在真正压测的时候会影响压测客户端的性能。

    例子2

    使用beanshell的assertion断言,完成一些响应结果判断的的操作。

    一个比较完整的代码框架如下,大家依葫芦画瓢就行了。

    import org.apache.jmeter.assertions; 
    import org.apache.jmeter.samplers.SampleResult; 
    import org.apache.jmeter.assertions.AssertionResult; 
    import org.json.*;


    String response_data = prev.getResponseDataAsString();//获取接口返回的response数据 

    JSONObject data_obj = new JSONObject(response_data);//转换成json 

    //判断code是否等于0 如果等于0 再取里面的字段 

    String code = data_obj.get(“code”); 

    if(code.equals(“0”)) 



    String user_name = data_obj.get(“data”).get(“user”).get(“userName”).toString(); 

    //这里的my_name 是用户自定义的变量或者之前的接口返回获取的 

        if(user_name.equals(${my_name})){ 

        Failure = false; //设置成false 表示接口跑成功,在结果树中sample是绿色的 

    //做后续动作 

         ……. 

        } 

        else{ 

          //做其他动作 

        } 



    else 



    Failure = true;//直接判断失败,表示接口跑失败,在结果树中sample是红色的 

    prev.setStopThread(true);//如果断言失败,后面的接口不需要再跑,直接暂停 

    }

     

    技巧

    高级用法:假如我们希望线程之间共享一个变量,可以利用BeanShell来完成。

    JMeter中线程间共享变量可以通过定义属性值来完成,JMeter启动时会读取一些属性文件,比如jmeter.properties、user.properties,这些属性值是可以修改的,通过BeanShell可以对其进行更改。通过props.put()来修改属性,props.get()来获取属性。

    学而不思则罔,思而不学则殆
  • 相关阅读:
    log4j中Spring控制台输出Debug级信息过多解决方法
    spring使用aop
    过滤器(filter)实现用户登录拦截
    Eclipse将项目部署tomcat的webapps目录
    css初始化样例代码
    dede表单修改默认必填
    DedeCMS提交自定义表单加入验证码功能
    jQuery入门第三天
    jQuery入门第二天
    jQuery入门第一天
  • 原文地址:https://www.cnblogs.com/linyu51/p/13970434.html
Copyright © 2020-2023  润新知