Jmeter就不过多介绍了,作为后台开发者日常性能测试免不了使用,今天记录下使用Jmeter使用beanshell方法介绍,并实现一个报文加解密的实现过程,首先在这之前我基本没有使用过beanshell经验,也是记录下我如何从0到1调试过程。
首先介绍下我使用的Jmeter是5.1.1版本。
跳过下Jmeter的基本操作,创建线程组,创建http请求,创建结果观察监视器等等操作,直接进入JSR223创建介绍。
创建请求内容加密的前置处理器;
创建好后我选择的是java语言的beanshell脚本(关于beanshell的介绍可以自行谷歌,大体就是能在我们编写的程序中运行java代码片段的支持库)
在beanshell脚本编写之前,需要大家先把加解密相关操作先使用java编写好然后打成jar包放在Jmeter的lib/ext/下,具体如何操作可以自行了解如何编译jar包方法(我使用maven的maven-assembly-plugin插件完成);
代码中的入口方法我也一并贴下:
接下来开始正活,beanshell脚本编写,jmeter中有提示,有如下属性咋们可以直接使用,但是具体怎么用呢;
看文档是第一选择,但是内网工作环境的我找网络资源比较难受,我们直接从源码上整活;首先我要知道这些属性到底是那些类型,我先使用调试的方法得到他们的类型:
然后新建一个工程,把Jmeter中lib下的所有jar包全部导入,然后搜索对应属性的api进行测试;
经历过N次的测试联调方法,终于找到获取POST中JSON的内容的方法,测试得出所有请求的参数信息都在sampler(org.apache.jmeter.protocol.http.sampler.
HTTPSamplerProxy)属性中;
创建响应内容解密的后置处理器;
预览下最终效果,请求是明文内容:
真实发起是密文
响应结果也解密成功
感谢观看,有啥相关技术讨论欢迎评论区留言。