一文1600字手把手教你使用Jmeter轻松实现AES加密测试

1438 篇文章 112 订阅
1424 篇文章 66 订阅

大家在自己公司做接口测试的时候,有没有遇到过接口做加密处理的情况呢?相信我们的读者朋友们都有一定的概率会遇到这种情况,尤其是对接口数据安全有一定要求的公司接口数据一定会做加密处理。那么遇到加密情况,大家使用工具JMeter如何做接口测试呢?可以借助JMeter提供的函数digest和MD5,其中digest支持的加密方法是如下这7个:

MD

SHA

MD2

MD5

SHA-1

SHA-224

SHA-256

SHA-384

SHA-512

由此可见到目前为止,JMeter自带的支持的加密方法仅MDSHA,如果很幸运你所供职公司用的就是这两种加密中的任意一种,那么我们就可以通过JMeter提供的加密方法进行加密处理。但是我们很多读者遇到的是使用其他的通用加密算法,一说到通用加密方法,不得不说AES加密,AES加密算法是英文单词Advanced Encryption Standard的首字母缩写,AES加密采用的是效率较高的对称加密算法,也就是说,其加密、解密使用相同的密钥。

AES网络传输过程加密、解密过程详见如下图所示

术语说明:

  • 明文:没有经过加密处理的数据

  • 密文:经过加密处理后的数据

如果大家公司业务对应的接口是走AES加密,我们通过接口测试工具JMeter做接口测试时,需要对请求数据做加密处理,并且对应答数据做解码处理,我们拿响应数据解密处理来看,具体怎么实现接口aes解密处理。

01、解密方法获取

首先我们要获取到aes解密方法,可以跟开发要,也可以网上找,毕竟aes是比较通用的加密算法

如下所示,是某公司开发提供的aes解密方法:

02、加密方法引入

接下来我们就需要将获取到的加密方法引入到JMeter中,有多种解决方案,咱们这里使用引入java源文件的方式,首先将java源文件拷贝到指定的盘符,例如:D盘。

然后在添加的beanshell后置处理器中增加如下脚本,来实现引入带加密方法的java源文件:

03、调用解密方法

如下脚本所示:

  • 第4行实现调用aes解密方法,入参有2个,分别是aes密文字符串、秘钥

  • 第2行定义aes密文字符串

  • 第3行表示获取应答报体,并赋值给aes密文字符串变量decodeStr

  • 第4行在日志查看面板打印应答报体aes明文

如下图所示,是经过aes解密后的应答报体内容:

经过以上步骤一、二、三操作即可实现对aes密文的解密。

接口请求aes加密,需要获取aes加密方法,不同于解密操作步骤是步骤三,调用的是获取到的aes加密方法。

04、URL解码

有些公司开发还会对应答报体进行URL编码处理,这种情况下,我们做接口、性能测试时,需要对应答做断言判断,因而需要先进行URL解码,然后再进行aes解密操作,然后再对解密后的应答信息做断言处理

如下所示在JMeter的BeanShell 后置处理程序中已编写的脚本中,增加第5行调用url解码方法对应答报体做url解码处理,当然JMeter自带的urldecode函数也能实现url解码处理,第1行实现的是引入java.net包下的URLDecoder类,提供给第5行url解码方法调用,其他脚本行的注释内容详见步骤三,这里就不再赘述了

相应的开发对接口请求也会做对应的URL编码处理,我们测试的接口脚本就需要增加如下两行脚本。

以上就是AES+URL接口的JMeter解决方案。


资源分享

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走

​这些资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。希望对大家有所帮助……【在下方我的公众号里获取】

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你想在Postman中对请求参数进行AES加密,你可以在"Pre-request Script"选项卡中使用CryptoJS库来实现。下面是一个示例代码,展示了如何在Postman中对请求参数进行AES加密: ```javascript // 引入CryptoJS库 const CryptoJS = require('crypto-js'); // 定义AES加密函数 function encryptAES(text, key, iv) { const encrypted = CryptoJS.AES.encrypt(text, key, { iv: iv }); return encrypted.toString(); } // 设置密钥和初始化向量 const key = CryptoJS.enc.Utf8.parse('1234567890123456'); // 设置密钥,必须是16位 const iv = CryptoJS.enc.Utf8.parse('1234567890123456'); // 设置初始化向量,必须是16位 // 加密请求参数 const plaintext = pm.request.body.raw; // 获取原始请求参数 const ciphertext = encryptAES(plaintext, key, iv); pm.request.body.raw = ciphertext; // 将加密后的参数设置为请求体 // 设置请求头 pm.request.headers.add({ key: 'Content-Type', value: 'application/json', }); pm.request.headers.add({ key: 'Encryption-Algorithm', value: 'AES', }); ``` 在上述代码中,我们首先引入CryptoJS库并定义了AES加密函数。然后,我们设置了密钥和初始化向量。接下来,我们获取原始请求参数并使用AES加密函数对其进行加密。最后,我们将加密后的参数设置为请求体,同时设置了相应的请求头。 请注意,上述代码假设请求参数是以JSON格式进行传输的,且请求头中有一个名为"Encryption-Algorithm"的自定义段,用于指明采用的加密算法。根据你的实际需求,你可能需要对代码进行适当的调整。 注意:在实际应用中,为了安全起见,你可能需要将密钥和初始化向量存储在安全的地方,并在运行时从该地方读取,而不是在代码中明文写入。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值