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
本文详细介绍了如何在JMeter中集成第三方jar包实现SHA-256加密,包括开发环境搭建、代码编写、jar包导出与导入、Beanshell语句编写等步骤,助力接口测试中的动态请求字段加密。
3011

被折叠的 条评论
为什么被折叠?



