Jmeter 使用 HMACSHA256 计算验签
程序员文章站
2022-03-06 17:49:03
...
在做压测的时候,需要批量调用接口,但是有些接口做了访问限制,需要根据当前时间戳和请求的body计算验签。
可以在jmeter 的 beanshell 里通过 HMACSHA256 计算验签
第一步 导出 HMACSHA256 jar包
程序源码 HMACSHA256 .java
package com.Base64;
import javax.crypto.Mac;
import javax.crypto.spec.SecretKeySpec;
public class HMACSHA256 {
/**
* 将加密后的字节数组转换成字符串
*
* @param b 字节数组
* @return 字符串
*/
public static String byteArrayToHexString(byte[] b) {
StringBuilder hs = new StringBuilder();
String stmp;
for (int n = 0; b!=null && n < b.length; n++) {
stmp = Integer.toHexString(b[n] & 0XFF);
if (stmp.length() == 1)
hs.append('0');
hs.append(stmp);
}
return hs.toString().toLowerCase();
}
/**
* sha256_HMAC加密
* @param message 消息
* @param secret 秘钥
* @return 加密后字符串
*/
public static String sha256_HMAC(String message, String secret) {
String hash = "";
try {
Mac sha256_HMAC = Mac.getInstance("HmacSHA256");
SecretKeySpec secret_key = new SecretKeySpec(secret.getBytes(), "HmacSHA256");
sha256_HMAC.init(secret_key);
byte[] bytes = sha256_HMAC.doFinal(message.getBytes());
hash = byteArrayToHexString(bytes);
} catch (Exception e) {
System.out.println("Error HmacSHA256 ===========" + e.getMessage());
}
return hash;
}
}
根据此代码 编译生成 jar 包,生成方式参考连接 :jhttps://blog.csdn.net/hellohm/article/details/9718369
稍后把打包生成的jar包上传。
导入完成以后 将jar包放在 jemter的 /lib/ext 目录下就能使用。
第二步 使用 jmeter 的 beanshell 计算验签。
新建http请求后,在下面加一个前置处理器: BeanShell PreProcessor
BeanShell 脚本示例