Jmeter使用python的SM4加密

文章介绍了如何将Python的pysm4库集成到JMeter中,首先需要将Jython添加到JMeter的lib/ext目录,然后在本地Python环境中安装pysm4,最后在Jmeter脚本中导入并使用pysm4进行ECB模式的加密操作。

1、Jmeter 扩展Python语言支持

下载:Downloads | Jython

把下载的jython-standalone-2.7.2.jar 放到 jmeter的lib/ext文件夹,重启Jmeter

2、在本地的python环境安装pysm4

下载地址:pysm4: 国密SM4(无线局域网SMS4)算法, 一个分组算法, 分组长度为128bit, 密钥长度为128bit, 算法具体内容参照SM4算法。

下载到本地后解压,进入文件夹内,执行python setup.py install

3、在Jmeter中调用pysm4

import sys
#这里不引用可能会报错
sys.path.append('D:\Python\Lib')
sys.path.append('D:\Python\Lib\site-packages')
from pysm4 import encrypt_ecb;


text2 = encrypt_ecb("admin", "你的key");

vars.put("key",text2);

### 如何在 JMeter 中实现 SM4 加密 由于 JMeter 的内置功能对于特定加密算法的支持有限,为了实现在 JMeter使用 SM4 加密的功能,可以采用 Beanshell 或者 JSR223 Sampler 来嵌入 Java 代码片段来完成这一目标。下面提供了一个基于 JSR223 Sampler 和 Bouncy Castle 库的解决方案。 #### 准备工作 首先,在执行任何操作之前,确保下载并安装了最新版本的 Bouncy Castle 提供程序 jar 文件,并将其放置于 JMeter 的 `lib` 目录下以便加载自定义的安全服务提供商 (SSP)[^1]。 #### 实现 SM4 加密的方法 创建一个新的 JSR223 Sampler 并配置如下所示: ```groovy import org.bouncycastle.jce.provider.BouncyCastleProvider; import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; import java.security.Security; // 添加BouncyCastle作为安全提供者 Security.addProvider(new BouncyCastleProvider()); String key = "your-secret-key-here"; // 定义用于加密解密的秘密钥匙 String dataToEncrypt = vars.get("data"); // 获取要被加密的数据变量 byte[] encryptedDataBytes; try { SecretKeySpec secretKey = new SecretKeySpec(key.getBytes(), "SM4"); Cipher cipher = Cipher.getInstance("SM4/ECB/PKCS7Padding", "BC"); cipher.init(Cipher.ENCRYPT_MODE, secretKey); byte[] plainTextByte = dataToEncrypt.getBytes(); encryptedDataBytes = cipher.doFinal(plainTextByte); } catch (Exception e) { log.error(e.getMessage()); } vars.put("encryptedData", Hex.toHexString(encryptedDataBytes)); // 将加密后的数据存储到另一个JMeter变量中 ``` 上述脚本实现了通过给定的秘密键对指定字符串进行 SM4 ECB 模式的加密过程,并将结果保存在一个新的 JMeter 变量里以供后续测试步骤调用。 请注意替换 `"your-secret-key-here"` 和 `vars.get("data")` 为实际使用的秘密钥以及待处理的数据源名称。 #### 注意事项 - 上述例子采用了最简单的 ECB 工作模式;然而,在生产环境中建议考虑更复杂的 CBC 等模式以增强安全性。 - 如果遇到性能瓶颈,则可能需要评估是否适合继续沿用此方法或是寻找其他替代方案。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值