这是我在JSR223预处理器中的代码。
import javax.crypto.Mac
import javax.crypto.spec.SecretKeySpec
import java.security.InvalidKeyException
import java.security.MessageDigest
import groovy.json.JsonSlurper
import java.text.SimpleDateFormat
static byte[] HmacSHA256(String data, byte[] key) throws Exception {
String algorithm="HmacSHA256";
Mac mac = Mac.getInstance(algorithm);
mac.init(new SecretKeySpec(key, algorithm));
return mac.doFinal(data.getBytes("UTF8"));
}
static byte[] getSignatureKey(String key, String dateStamp, String regionName, String serviceName) throws Exception {
byte[] kSecret = ("AWS4" + key).getBytes("UTF8");
byte[] kDate = HmacSHA256(dateStamp, kSecret);
byte[] kRegion = HmacSHA256(regionName, kDate);
byte[] kService = HmacSHA256(serviceName, kRegion);
byte[] kSigning = HmacSHA256("aws4_request", kService);
return kSigning;
}
getSignatureKey函数的示例参数值是(这些参数值将作为变量传递给JSR223 PreProcessor的Parameters部分)
key = eC6hEyRSTXMzsG6+juOObz8LbXb36iEYW7PPN1MJ
dateStamp = 20190123T083434Z
regionName = us-west-2
serviceName = test-mlp-us-west-2-4023179c-7708-4c5e-a831-28259b8a8872.s3.us-west-2.amazonaws.com
此代码不起作用,并且不会生成AWS签名。
这是我需要获取的示例签名值
Signature=2a6092ec4ff49dc9j3b92d436635a57f312753kcc9f553ce1718b9b1594c4362
1。此代码有什么问题? 2.如何将AWS签名分配给变量并在JMeter中使用?
答案 0 :(得分:0)
如果“此代码无法正常工作”,您首先应该研究jmeter.log file-如果Groovy脚本失败,它将包含有关确切失败原因,原因以及一些修复建议的信息。
我还认为您应该基于请求详细信息(URL,参数,标头等)生成签名
<C-R><C-W>
请参见Create a String to Sign for Signature Version 4
How to Handle Dynamic AWS SigV4 in JMeter for API Testing中描述了带有示例的整个过程,GitHub repo中提供了可用作参考的测试计划。