01 概述
为什么需要做二次开发?JMeter作为一款开源的性能、接口测试工具,有时候无法满足我们工作的需要,一般体现在:协议不支持、没有相应数据处理功能等。
一般这种情况下,我们可以做的选择有:
第一种找插件
第二种自定义实现
JMeter二次开发一般又分为三类情况:
自定义组件、依托于JMeter的core的jar实现。一般来说,代码量较大
依托于java请求实现自定义协议的扩展。推荐方式
自定义函数来实现特定的一些数据处理的功能。(和服务器没有交互),比如加密、签名的生成、编码处理,解密等等。
02 基于java请求的二次开发
首先,我们依赖的jar包分为两种:
JMeter框架层面的:实现的是性能层面的统计相关工作。需要的jar包有ApacheJMeter_core.jar,是JMeter的核心jar包 ,所有基于JMeter的二次开发基本上都需要用到该jar包。
基于jave请求所以还需要ApacheJMeter_java.jar
扩展的协议本身所需要的:取决于协议本身
接下来打开eclipes,导入需要的jar包,自定义的java请求要继承Jmeter所提供的.AbstractJavaSamplerClient类。可以看到这里需要重写的方法是runTest方法。
我们先写一个简单的例子,认识一下常见的方法:
将该项目导成jar包,放到JMeter lib目录下,ext文件中
如何设置传入参数?
重写getDefaultParameters()方法,在runtest方法中,使用arg0. getParameter(“参数名”)调用
代码:
效果:
到这里的话,我们就把JMeter层面的东西搞定了,那么我们怎么让他实现我们想要的功能?
这个时候就要用到扩展协议所需要的jar包了,我们把这个jar也导入到eclipse中,在runTest方法中调用,设置其返回结果,这样就可以在这里面应用了,因本人实力有限,这个地方举一个简单的例子。假设我们的业务(和服务器交互)是一个计算器,代码如下:
在JMeter框架中我们实现的操作就是设置传入的参数,一般和业务有关,方法就用getDefaultParameters:
其次是runTest方法,我们要做的第一步就是获取传到的参数,使用arg0. getIntParamete方法,实例化业务对象,实例化SampleResult对象,开始计时,业务处理,设置结果,设置状态,结束计时,返回SampleResult对象即可。
有需要时,可在语句中使用try catch抛出异常,对异常状态进行处理
最后导出jar包即可,运行效果:
这里需要注意的是业务类:
业务类所依赖的类都必须以jar包的形式存在于Jmeter的lib目录下,以及业务类所以依赖的类,有可能在Jmeter的lib目录中本身就存在。有可能会版本不一致,此时需要进行评估,一般保留高版本(前提是能够兼容低版本才行)。否则就可能需要进行代码层面的变更,使用统一的版本来实现。
03 JMeter自定义函数
在使用JMeter的过程中,我们经常会需要进行各种各样的数据处理,比如说编码、解码、加密、解密、特定的值生成,如果JMeter本身没有提供,我们则可以通过自定义函数的方式,实现扩展。
我们依赖的jar包有哪些呢?
首先JMeter层面,依赖的jar包主要有两个ApacheJMeter_core.jar以及ApacheJMeter_functions.jar两个包,功能本身所依赖的包就是功能实现的jar包,功能本身是脱离JMeter存在的。
首先我们还是导入JMeter的jar包,创建javaproject项目,创建包,注意package中必须包含关键字functions,创建类,继承自AbstractFunction。
这里需要重写的方法有四个:
该方法就是返回Hello World,如果在使用时,在execute中调用功能包并返回结果,我们看一下怎么传递参数
导出jar包做法和基于java请求一样,测试结果如下:
我们会发现一个问题,就是当使用参数调用函数不能被调用,如图,那么要怎么处理呢?
函数的入参本身是Jmeter的一个参数(类似于${xxx}),则需要进行二次转化,操作方法如下:
导出jra包,运行脚本结果为:
这里就不在说如何调用功能jar包,处理方法和基于java请求二次开发一样,在execute方法中进行调用,返回结果即可,这里也要把功能的jar包也要放到lib目录下。
小技巧:
如果希望将依赖包放在lib以外的目录,则建议修改Jmeter的配置文件jmeter.properties. 中 user.classpath
自定义函数,其package中必须包含关键字functions具体以Jmeter.properties文件中的配置项为准。
classfinder.functions.contain=.functions