Jmeter二次开发实现rsa加密
jmeter函数助手提供了大量的函数,像 counter、digest、random、split、strLen,这些函数在接口测试、性能测试中大量被使用,但是大家在实际工作,形形色色的测试需求不同,导致jmeter自带或者扩展插件给我们提供的函数无法全部满足,这个时候我们就可以自己动手,对JMeter进行二次开发。
接下来我拿aes加密来说明如何实现JMeter二次开发。
首先需要将jmeter的core、functions两个jar包导入到项目工程中。
这两个jar包在jmeter的lib\ext目录下,包的完整名如下所示:
ApacheJMeter_core.jar
ApacheJMeter_functions.jar
接下来定义类,类名Rsa0706,继承抽象类AbstractFunction,
实现其中的4个方法execute()、setParameters()、getReferenceKey()、getArgumentDesc(),具体代码如下所示:
1、getReferenceKey方法实现
getReferenceKey()方法是用于返回自定义函数的名字,以下代码定义了类成员变量key,值为字符串“__rsa”,key 这个变量的值作为getReferenceKey()方法的返回值。
2,getArgumentDesc方法实现
getArgumentDesc()用来定义jmeter各入参的描述信息,
咱们要封装的jmeter的rsa加密函数有两个入参,分别是要加密的字符串(即明文),以及加密的公钥,如下代码所示,定义类成员变量desc,将两个入参的描述信息存到这个变量中,作为getArgumentDesc()方法的返回值。
3,setParameters方法实现
setParameters()方法用于获取JMeter函数的入参值,咱们rsa加密需要两个入参,分别是明文、公钥,参数个数是2,在setParameters()方法需要先检查入参个数的最大值、最小值是不是2,然后将参数集合Collection转成数组存到Object数组变量values中,并定义类成员变量MAX_PARA_COUNT、MIX_PARA_COUNT、plaintextCV、publicKeyCV,分别存最大变量个数、最小变量个数、明文、公钥。
4,execute方法实现
方法execute()里定义的是Jmeter自定义函数的主要逻辑代码,咱们这里放aes加密方法的业务逻辑实现
然后将调试好的项目打成jar包,拷贝到jmeter的lib\ext目录下。
启动jmeter,可以在jmeter的函数助手界面看到,自定义的__rsa函数,如下截图所示。
例如公钥:
MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQClvArPDQsHpny6fNi1dVyjwz6GTtuKZ5hy8qb62ndCiGXgH5d9WSPeH6RIA14SMGwFwXAd2btntdmvs0CXtSDRP7cXiomEDgBSoDyNbjblQWFKKresjHuxka37rKUgwsDmsaCBE75nUVghJnqmZBhmZ/m9USdsfBbKPogpuVrNtwIDAQAB
1234567890这串明文经过rsa公钥加密之后,结果如下截图所示
b9U55CVXTK+LOWuJPscL/074YtDNTr7fQCitxr73Sq9y4/P7q+TY+lm/L5QpTI8cpnJc6Q6V2I6WSUHFsSFmibwsAacdlIWbvjGxIy2z7F+Y0Ymj32GsFpbi85ea4GFhvrvzYDKp1IRUqo4oCWSwx6zV43gD3NFQHaoKKaU91As=
然后将调试好的项目打成jar包,拷贝到jmeter的lib\ext目录下。
启动jmeter,可以在jmeter的函数助手界面看到,自定义的__rsa函数,如下截图所示。
例如公钥:
MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQClvArPDQsHpny6fNi1dVyjwz6GTtuKZ5hy8qb62ndCiGXgH5d9WSPeH6RIA14SMGwFwXAd2btntdmvs0CXtSDRP7cXiomEDgBSoDyNbjblQWFKKresjHuxka37rKUgwsDmsaCBE75nUVghJnqmZBhmZ/m9USdsfBbKPogpuVrNtwIDAQAB
1234567890这串明文经过rsa公钥加密之后,结果如下截图所示
b9U55CVXTK+LOWuJPscL/074YtDNTr7fQCitxr73Sq9y4/P7q+TY+lm/L5QpTI8cpnJc6Q6V2I6WSUHFsSFmibwsAacdlIWbvjGxIy2z7F+Y0Ymj32GsFpbi85ea4GFhvrvzYDKp1IRUqo4oCWSwx6zV43gD3NFQHaoKKaU91As=
最后: 可以在公众号:伤心的辣条 ! 自行领取一份216页软件测试工程师面试宝典文档资料【免费的】。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。
现在我邀请你进入我们的软件测试学习交流群:【746506216
】,备注“入群”, 大家可以一起探讨交流软件测试,共同学习软件测试技术、面试等软件测试方方面面,还会有免费直播课,收获更多测试技巧,我们一起进阶Python自动化测试/测试开发,走向高薪之路。
喜欢软件测试的小伙伴们,如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一 键三连哦!
软件测试工程师自学教程:
这才是2022最精细的自动化测试自学教程,我把它刷了无数遍才上岸字节跳动,做到涨薪20K【值得自学软件测试的人刷】
软件测试工程师月薪2W以上薪资必学技能 — Python接口自动化框架封装.
美团面试真题_高级测试25K岗位面试 — 软件测试人都应该看看
软件测试必会_Jmeter大厂实战 — 仅6步可实现接口自动化测试
相关文章
- 探讨.NET Core中实现AES加密和解密以及.NET Core为我们提供了什么方便!
- [C#] AES 加密
- TLS实现代码段加密
- [转] js在浏览器端对二进制流进行AES加密和解密
- Python下载M3U8加密视频示例
- 接口测试框架实战 | 流程封装与基于加密接口的测试用例设计
- iOS CommonCrypto 对称加密 AES ecb,cbc
- 使用Jmeter轻松实现AES加密测试
- 公钥私钥 加密解密
- 安全篇-AES/RSA加密机制
- SpringBoot 通过Filter与AOP实现请求加密解密功能
- 破解ZIP加密文件密码fcrackzip
- JSON 接口如何实现 RSA 非对称加密与签名
- Kafka实战:集群SSL加密认证和配置(最新版kafka-2.7.0)
- firebase/php-jwt使用openssl实现 RSA非对称加密
- Excel—在Excel中利用宏定义实现MD5对字符串(如:手机号)或者文件加密
- nodejs基础(管道、流)实现:复制、压缩、加密、解压,解密,写入文件
- 前端和Java后端的AES加密和解密
- java 对视频和图片进行加密解密[转]
- 希捷推出新的数据加密功能,旨在加强网络安全
- Unity 基础 之 实现简单的Android移动端本地数据读取与写入封装(简单加密写入,解密读取 json 数据)
- 两个人之间发加密的微信信息,可以用这个键盘实现
- 【sql server安全】sql server使用混合密钥实现列加密
- 【sql server安全】sql server使用非对称秘钥实现列加密
- 【sql server安全】sql server使用对称秘钥实现列加密
- java代码实现python2中aes加密经历
- java RSA加密解密--转载
- Spring Security(3)----用户密码加密实现
- Java实现文件MD5加密