jmeter 接口測試導入第三方jar
-
導語:
- 接口測試時總會出現 臨時加密或需要變動的請求字段,對此我們可以採用jar包形式,獲得請求中需要的字段。
-
實踐:
- 接口加密規則多樣化,我們只需要根據接口文檔指定的加密格式進行處理即可,以下爲sha256 加密詳解。
- 1. 搭建開發環境(作者採用Eclipse,可根據自己使用習慣自定義)
- 2. 創建工程(以下爲maven工程)
- 3. 編寫代碼:
package com.jmeter;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class Sha256 {
/**
* 將byte轉爲16進制
*
* @param bytes
* @return
*/
public static String byte2Hex(byte[] bytes) {
StringBuffer stringBuffer = new StringBuffer();
String temp = null;
for (int i = 0; i < bytes.length; i++) {
temp = Integer.toHexString(bytes[i] & 0xFF);
if (temp.length() == 1) {
// 1得到一位的進行補0操作
stringBuffer.append("0");
}
stringBuffer.append(temp);
}
return stringBuffer.toString();
}
/**
* sha256_HMAC加密
* @param message 消息
*
* @param secret 祕鑰
* @return 加密後字符串
*/
public static String sha256(String str) {
MessageDigest messageDigest;
String encodestr = "";
try {
messageDigest = MessageDigest.getInstance("SHA-256");
messageDigest.update(str.getBytes("UTF-8"));
encodestr = byte2Hex(messageDigest.digest());
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
// System.out.println("encodestr********:"+encodestr);
return encodestr;
}
}
- 4.導出jar包
- 5. 導出指定路徑即可 %jmeter%/lib/
- 6. 添加線程組
- 7. 添加beanshell
- 8. 添加請求及查看結果樹
- 6. 編寫beanshell語句
import com.jmeter.*;
String test ="123";
Sha256 getsign =new Sha256();
String sign=getsign.sha256(test);
log.info("加密簽名:"+ sign.toString());
特別注意後導入的jar包需要重啓Jmeter纔可以生效。否則將出現:Typed variable declaration : Class: Sha256 not found in namespace