一、在eclipse里面編寫(xiě)MD5加密算法
package com.Base64;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class Md5Utils {
public static String md5(String sourceStr) {
String result = "";
try {
MessageDigest md = MessageDigest.getInstance("MD5");
md.update(sourceStr.getBytes());
byte b[] = md.digest();
int i;
StringBuffer buf = new StringBuffer("");
for (int offset = 0; offset < b.length; offset++) {
i = b[offset];
if (i < 0)
i += 256;
if (i < 16)
buf.append("0");
buf.append(Integer.toHexString(i));
}
result = buf.toString();
// System.out.println("MD5(" + sourceStr + ",32) = " + result);
// System.out.println("MD5(" + sourceStr + ",16) = " + buf.toString().substring(8, 24));
} catch (NoSuchAlgorithmException e) {
// System.out.println(e);
}
return result;
}
public static void main(String[] args) {
String md5Str = md5("123456");
System.out.println(md5Str);
}
}
二、在eclipse里面自己編寫(xiě)HMACSHA256算法
package com.Base64;
import javax.crypto.Mac;
import javax.crypto.spec.SecretKeySpec;
public class HMACSHA256 {
/**
* 將加密后的字節(jié)數(shù)組轉(zhuǎn)換成字符串
*
* @param b 字節(jié)數(shù)組
* @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;
}
public static void main(String[] args) {
String data = sha256_HMAC("123", "abc");
System.out.println(data);
}
}
三、在eclipse里面寫(xiě)好之后,導(dǎo)出來(lái)為jar包,命名為:base64.jar??放在jmeter/lib/ext中
1.md5方法就一個(gè)參數(shù),就是需要加密的數(shù)據(jù)
2.sha256_HMAC方法接收兩個(gè)參數(shù),message:需要被加密的數(shù)據(jù),secret:加密的秘鑰
四、在jmeter測(cè)試計(jì)劃底部library中添加該jar包,重啟jmeter
新建http請(qǐng)求后,在下面加一個(gè)前置處理器:BeanShell?PreProcessor
直接導(dǎo)入該jar包里面的java包,Md5Utils和HMACSHA256都在在com.Base64這個(gè)包里,直接引入,如果導(dǎo)入不了在jmeter的測(cè)試計(jì)劃底部引入即可
插入如下代碼:
import com.Base64.*;
//1.測(cè)試通過(guò)MD5進(jìn)行加密
String md5Str = Md5Utils.md5("123456");
vars.put("loginPwd",md5Str); //把加密后的內(nèi)容賦值給到loginPwd變量
log.info(md5Str);
//2.測(cè)試通過(guò)HMACSHA256進(jìn)行加密
HMACSHA256 psSha256 = new HMACSHA256();
//調(diào)用HMACSHA256類的sha256_HMAC方法,進(jìn)行hmacsha256加密
//通過(guò)abc秘鑰對(duì)密碼123456進(jìn)行加密
String psStr=psSha256.sha256_HMAC("123456","abc");
log.info(psStr);
五、通過(guò)創(chuàng)建前置處理器beanshell腳本進(jìn)行加密處理
六、對(duì)加密后的數(shù)據(jù)進(jìn)行引用文章來(lái)源:http://www.zghlxwxcb.cn/news/detail-650362.html
文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-650362.html
到了這里,關(guān)于jmeter通過(guò)BeanShell對(duì)接口參數(shù)進(jìn)行MD5和HmacSHA256加密【杭州多測(cè)師_王sir】的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!