2026/4/17 2:27:17
网站建设
项目流程
如何建立营销性企业网站论文,网站速度优化工具,ui设计零基础好学吗,商城建站系统源码大家在自己公司做接口测试的时候#xff0c;有没有遇到过接口做加密处理的情况呢#xff1f;相信我们的读者朋友们都有一定的概率会遇到这种情况#xff0c;尤其是对接口数据安全有一定要求的公司接口数据一定会做加密处理。那么遇到加密情况#xff0c;大家使用工具JMeter…大家在自己公司做接口测试的时候有没有遇到过接口做加密处理的情况呢相信我们的读者朋友们都有一定的概率会遇到这种情况尤其是对接口数据安全有一定要求的公司接口数据一定会做加密处理。那么遇到加密情况大家使用工具JMeter如何做接口测试呢可以借助JMeter提供的函数digest和MD5其中digest支持的加密方法是如下这7个MDSHAMD2MD5SHA-1SHA-224SHA-256SHA-384SHA-512由此可见到目前为止JMeter自带的支持的加密方法仅MD和SHA如果很幸运你所供职公司用的就是这两种加密中的任意一种那么我们就可以通过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编码处理我们测试的接口脚本就需要增加如下两行脚本。以上就是AESURL接口的JMeter解决方案。感谢每一个认真阅读我文章的人礼尚往来总是要有的虽然不是什么很值钱的东西如果你用得到的话可以直接拿走这些资料对于【软件测试】的朋友来说应该是最全面最完整的备战仓库这个仓库也陪伴上万个测试工程师们走过最艰难的路程希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取