Jmeter使用beanshell实现报文自动加解密

Jmeter就不过多介绍了,作为后台开发者日常性能测试免不了使用,今天记录下使用Jmeter使用beanshell方法介绍,并实现一个报文加解密的实现过程,首先在这之前我基本没有使用过beanshell经验,也是记录下我如何从0到1调试过程。

首先介绍下我使用的Jmeter是5.1.1版本。

 

跳过下Jmeter的基本操作,创建线程组,创建http请求,创建结果观察监视器等等操作,直接进入JSR223创建介绍。

 

创建请求内容加密的前置处理器;

241702c0561f41d49f79293a45866ba2.png

创建好后我选择的是java语言的beanshell脚本(关于beanshell的介绍可以自行谷歌,大体就是能在我们编写的程序中运行java代码片段的支持库)

82230e74ef9b453787efe40a0756b77f.png

 

在beanshell脚本编写之前,需要大家先把加解密相关操作先使用java编写好然后打成jar包放在Jmeter的lib/ext/下,具体如何操作可以自行了解如何编译jar包方法(我使用maven的maven-assembly-plugin插件完成);

3385c1b5d0b24d178b2b7a23be190d3f.png

 

 

代码中的入口方法我也一并贴下:

84bd3b2a53154589855cf14c1d6c739f.png

 

接下来开始正活,beanshell脚本编写,jmeter中有提示,有如下属性咋们可以直接使用,但是具体怎么用呢;

462ed8adb161434ab8b57dd014c51c24.png

 

看文档是第一选择,但是内网工作环境的我找网络资源比较难受,我们直接从源码上整活;首先我要知道这些属性到底是那些类型,我先使用调试的方法得到他们的类型:

4779ecae094047389bee3020a351cdf0.png

 

然后新建一个工程,把Jmeter中lib下的所有jar包全部导入,然后搜索对应属性的api进行测试;

d04d677bf065429caef690c3818b6246.png

 

经历过N次的测试联调方法,终于找到获取POST中JSON的内容的方法,测试得出所有请求的参数信息都在sampler(org.apache.jmeter.protocol.http.sampler.

HTTPSamplerProxy)属性中;

 

 

05113d5519f04bbb9003c727b19527f8.png

 

创建响应内容解密的后置处理器;

750807e276e34185b62ac5650580c5fa.png

 

预览下最终效果,请求是明文内容:

106aa7b878b642d5a5f128e6ca1a9c99.png

 

真实发起是密文

82eb947b31ee4b428a27ebb266adf5b3.png

响应结果也解密成功

7d879467d685450f97e1f27da029f6e0.png

 

感谢观看,有啥相关技术讨论欢迎评论区留言。

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值