Jmeter導入第三方jar

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章