news 2026/6/22 17:17:13

使用Jmeter轻松实现AES加密测试

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
使用Jmeter轻松实现AES加密测试

大家在自己公司做接口测试的时候,有没有遇到过接口做加密处理的情况呢?相信我们的读者朋友们都有一定的概率会遇到这种情况,尤其是对接口数据安全有一定要求的公司接口数据一定会做加密处理。那么遇到加密情况,大家使用工具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解决方案。

感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 19:16:49

计算机毕业设计springboot基于微信小程序的核酸检测预约系统 基于微信小程序的 Spring Boot 核酸检测预约管理系统设计与实现 微信小程序结合 Spring Boot 的核酸检测预约平台

计算机毕业设计springboot基于微信小程序的核酸检测预约系统p14ug9 (配套有源码 程序 mysql数据库 论文) 本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。随着互联网技术的飞速发展,核酸检测预约系统的需求…

作者头像 李华
网站建设 2026/6/23 2:39:15

计算机视觉项目启动利器:PyTorch-CUDA开箱即用环境

计算机视觉项目启动利器:PyTorch-CUDA开箱即用环境 在现代AI研发的日常中,你是否经历过这样的场景?刚接手一个计算机视觉项目,满心期待地打开代码仓库,准备大展身手。可还没写一行模型逻辑,就被一连串报错拦…

作者头像 李华
网站建设 2026/6/22 13:18:32

收藏备用!企业级RAG落地全攻略:从避坑到选型的大模型实践手册

AI驱动决策的浪潮下,企业积累的海量文档、历史数据正成为待激活的“数字金矿”。检索增强生成(RAG)作为打通大模型与企业知识库的核心技术,已成为程序员搭建智能化系统的必学技能。但不少团队在落地时,总会踩上“非结构…

作者头像 李华
网站建设 2026/6/23 12:34:21

从Java到前端:一位全栈开发者的成长之路与技术探索

从Java到前端:一位全栈开发者的成长之路与技术探索 在互联网大厂的面试中,一个经验丰富的Java全栈开发者往往会面对一系列深入的技术问题。今天,我们以一场真实的面试为背景,讲述一位28岁、拥有5年工作经验的全栈工程师&#xff0…

作者头像 李华
网站建设 2026/6/23 11:29:39

14、Linux与Windows环境下NFS和NIS的使用指南

Linux与Windows环境下NFS和NIS的使用指南 1. NFS协议概述 NFS(Network File System)是原生的UNIX协议,允许UNIX机器通过网络共享驱动器,它与微软的SMB协议有部分功能相似,但更为简单,不包含认证和打印功能。认证由UNIX(或Linux)主机处理,打印功能由lpr和lpd处理。 …

作者头像 李华
网站建设 2026/6/23 7:05:56

15、Linux与Windows系统集成:NIS、FTP及Telnet配置指南

Linux与Windows系统集成:NIS、FTP及Telnet配置指南 在当今的网络环境中,Linux和Windows系统的集成是一个常见且重要的需求。本文将详细介绍NIS(网络信息服务)、FTP(文件传输协议)和Telnet在Linux和Windows系统中的配置与使用,帮助你更好地实现系统间的协同工作。 NIS相…

作者头像 李华