当前位置: 首页 > news >正文

jmeter中参数加密

加密接口常用的方式有:
MD5,SHA,HmacSHA
RSA
AES,DES,Base64

压测中有些参数需要进行加密,加密方式已接口文档为主。

MD5加密

比如MD5加密的接口文档:
请求URL:http://101.34.221.219:5000/md5login
请求方式:POST
请求参数:

参数名称参数值是否必须类型备注
usernameadminstring必须MD5加密处理
password123string必须MD5加密处理

1、用户名、密码不进行加密登录测试
在这里插入图片描述
在这里插入图片描述
用户名密码未进行MD5加密,登录失败。

2、用户名、密码进行加密登录测试
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
用户名密码加密,登录成功。

beanshell组件代码加密

目前jmeter的__digest函数支持的加密方式较少,jmeter用户手册
在这里插入图片描述
其他加密算法要在beanshell组件中编写
比如接口以AES方式加密,规则如下:

生成访问签名

参数名说明示例值备注
clientId签名ID0ca6eaf66cbf4f2bb1db6902c9c8d915
clientSecret签名秘钥8c0a5f3388154e2c959f2bd44fc2dd66
timestamp时间戳1706859156428当前时间戳
uuid唯一ID12345678唯一值,一个签名只能使用一次

1.1 访问签名生成逻辑

3.1.1、签名值= 签名ID+“:”+签名秘钥+“:”+时间戳+“:”+唯一ID

3.1.2、 生成算法:AES ,签名参数:ECB PKCS7 128bits

3.1.3、 AES算法秘钥(aesKey):#iSn##s$olu.@@sm

3.1.4、 access_sign生成规则:用AES算法对签名值进行加密

1.2 beanshell脚本编写

// Import the Base64 class
import org.apache.commons.codec.binary.Base64;// 参数
var clientId = "0ca6eaf66cbf4f2bb1db6902c9c8d915";
var clientSecret = "8c0a5f3388154e2c959f2bd44fc2dd66";
var timestamp = new Date().getTime();
var uuid = new java.util.Random().nextInt(90000000) + 10000000;// 计算签名值
var signValue = clientId + ":" + clientSecret + ":" + timestamp + ":" + uuid;// 加密签名值
var aesKey = "#iSn##s$olu.@@sm";
var cipher = javax.crypto.Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(javax.crypto.Cipher.ENCRYPT_MODE, new javax.crypto.spec.SecretKeySpec(aesKey.getBytes(), "AES"));
var encryptedSign = cipher.doFinal(signValue.getBytes());// 生成访问签名 (使用 Commons Codec)
var accessSign = new String(Base64.encodeBase64(encryptedSign));// 将访问签名存储到变量中
vars.put("access_sign", accessSign);// 打印访问签名
System.out.println("access_sign: " + accessSign);

参数替换即可
在这里插入图片描述

Base64加密

比如MD5加密的接口文档:
请求URL:http://101.34.221.219:5000/base64login
请求方式:POST
请求参数:

参数名称参数值是否必须类型备注
usernameadminstring必须Base64加密处理
password123string必须Base64加密处理

1、用户名、密码不进行加密登录测试
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
用户名密码未进行Base64加密,登录失败。

2、用户名密码进行Base64加密
2-1、http请求-添加-前置处理器-beanshell预处理程序在这里插入图片描述
2-2、输入代码,Base64加密代码固定

//Base64加密方式
import java.util.Base64;//初始化一个Base64对象,调用encodeToString()方法
String bs64_username = Base64.getEncoder().encodeToString("admin".getBytes("UTF-8"));
String bs64_password = Base64.getEncoder().encodeToString("123".getBytes("UTF-8"));//设置为线程组能够调用的变量
vars.put("bs64_username",bs64_username);
vars.put("bs64_password",bs64_password);//打印
log.info("bs64_username的结果是:"+bs64_username);
log.info("bs64_password的结果是:"+bs64_password);

2-3、日志查看对比
在这里插入图片描述
在这里插入图片描述

2-4、参数替换为变量,执行查看结果
在这里插入图片描述
在这里插入图片描述

http://www.lryc.cn/news/327512.html

相关文章:

  • YOLOv8改进 | 检测头篇 | 2024最新HyCTAS模型提出SAttention(自研轻量化检测头 -> 适用分割、Pose、目标检测)
  • verilog设计-cdc:多比特信号跨时钟域(DMUX)
  • 服务器停止解析域名,但仍然可以访问到
  • Centos系统与Ubuntu系统防火墙区别,以及firewalld、ufw和iptables三者之前的区别。
  • ES6 学习(三)-- es特性
  • 使用ChatGPT的场景之gpt写研究报告,如何ChatGPT写研究报告
  • librdkafka的简单使用
  • 【iOS ARKit】播放3D音频
  • ES学习日记(四)-------插件head安装和一些配套插件下载
  • flask+uwsgi+云服务器 部署服务端
  • linux学习之路 -- 普通用户添加进sudoer列表
  • 【分类评估指标,精确率,召回率,】from sklearn.metrics import classification_report
  • element-ui autocomplete 组件源码分享
  • 视觉SLAM理论与实践的学习链接汇总
  • 极光笔记|极光消息推送服务的云原生实践
  • 高效八股文背诵方法
  • Codeforces Round 841 (Div. 2) C. Even Subarrays
  • 用 SpringBoot+Redis 解决海量重复提交问题
  • 前端基础知识html
  • 网络原理-传输层-UDP报文结构
  • TCP/IP参考模型(四层及其解析)
  • 2024第六届环境科学与可再生能源国际会议能源 (ESRE 2024) 即将召开!
  • CentOS配置docker外部访问
  • 面试前端八股文十问十答第二期
  • 【漏洞复现】大华综合安防监控管理平台 Digital Surveillance System系统存在RCE漏洞
  • ssm网上订餐管理系统开发mysql数据库web结构java编程计算机网页源码eclipse项目采用线性算法
  • python 进程之由浅入深
  • 公链角逐中突围,Solana 何以成为 Web3 世界的流量焦点?
  • 算法设计-杨辉三角
  • Linux swatch命令教程:实时监视系统活动(附实例详解和注意事项)