欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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
Jmeter 使用 HMACSHA256 计算验签
BeanShell 脚本示例
Jmeter 使用 HMACSHA256 计算验签

相关标签: 测试