jmeter--8.加密传输

目录

1. Base64加密

2. MD5加密

3. SHA加密(sha1\sha\sha224\sha256\sha384\sha512)

4. RSA加密-公钥加密,私钥解密


1. Base64加密

1.1 在需要加密传输的接口下新增BeanShell 预处理程序,${username}可替换成value值,但是不利于参数化

import java.util.Base64;
//初始化一个Base64对象,调用encodeToString()方法
String Musername = Base64.getEncoder().encodeToString("${username}".getBytes("UTF-8"));
String Mpassword = Base64.getEncoder().encodeToString("${password}".getBytes("UTF-8"));
log.info(Musername);
log.info(Mpassword);
//设置变量
vars.put("Musername",Musername);
vars.put("Mpassword",Mpassword);

2. MD5加密

2.1 使用函数助手进行加密

${__digest(MD5,${username},,,)}

2.2 使用beanshell进行加密

在需要加密传输的接口下新增BeanShell 预处理程序

//导包
import org.apache.commons.codec.digest.DigestUtils;
//md5加密
String Musername = DigestUtils.md5Hex("${username}");
String Mpassword = DigestUtils.md5Hex("${password}");
//传值
vars.put("Musername",Musername);
vars.put("Mpassword",Mpassword);

3. SHA加密(sha1\sha\sha224\sha256\sha384\sha512)

3.1 使用函数助手进行加密--注意函数助手不支持sha-3加密

${__digest(sha-1,${username},,,)}

2.2 使用beanshell进行加密

import org.apache.commons.codec.digest.DigestUtils;
String username = DigestUtils.sha512Hex("${username}");
String password = DigestUtils.sha512Hex("${password}");
log.info("username加密结果为:"+username);
log.info("password加密结果为:"+password);

4. RSA加密-公钥加密,私钥解密

需要引入python脚本进行加密--公钥根据接口需求获取(可以直接问开发),这里只是一个示例

#通过公钥加密
def rsa_jiami():
    # 接收cmd命令里面的参数
    parse = argparse.ArgumentParser()
    parse.add_argument("-t", "--ticket", action="append")
    args = parse.parse_args()
    ticket = args.ticket
    #print("ticket:%s" % ticket)
    #导入公钥
    public_key_str = "-----BEGIN RSA PUBLIC KEY-----\nMIGJAoGBALO7UPE26anTGHND2Q54zYYPusDx+tbO1Yia7zoxpZediw+Baea7aFZC\nJ+ZvWd5ZBTopuWvb8hNkY24eBHcXN0pU32WjsH9REp1kXhxbndnw+u3diaoUFqVc\n66xl+LXEo1Y9oDWfkGCir2JnN0aieUiPlHDLhmc+LII/ZDspITKDAgMBAAE=\n-----END RSA PUBLIC KEY-----"
    pubkey = rsa.PublicKey.load_pkcs1(public_key_str.encode())

    #加密用户名
    username_str = rsa.encrypt(str(ticket[0]).encode("utf-8"),pubkey)
    #把二进制转化成字符串格式
    username_miwen = base64.b64encode(username_str).decode("utf-8")
    print(username_miwen)
    print("测试")
    # 加密密码
    password_str = rsa.encrypt(str(ticket[1]).encode("utf-8"), pubkey)
    # 把二进制转化成字符串格式
    passsword_miwen = base64.b64encode(password_str).decode("utf-8")
    print(passsword_miwen)

if __name__ == '__main__':
    rsa_jiami()

beanshell调用

注意这里需要安装rsa,不然会引用失败。在控制台安装【pip install rsa】

import java.io.BufferedReader;  //导包
import java.io.InputStreamReader;

String command = "cmd /c python D:/study/course/Jmeter/RSAjiami.py -t ${username} -t ${password}";  //组建cmd命令并执行py文件
Runtime rt = Runtime.getRuntime(); //初始化一个运行时对象
Process pr = rt.exec(command); //通过运行时对象运行cmd命令。

pr.waitFor();  //运行时等待

//调用pr进程对象获取到它的输入流。读取pr文件流的内容,并且保存到reponse_data
BufferedReader br = new BufferedReader(new InputStreamReader(pr.getInputStream()));
StringBuilder response = new StringBuilder();
String line = "";
while((line=br.readLine())!=null){
    response.append(line);
};
String reponse_data = response.toString();
br.close();

log.info("reponse_data:"+reponse_data);//打印返回的内容

//获取用户名和密码
String[] miwen = reponse_data.split("测试");
log.info(miwen[0]);
log.info(miwen[1]);
vars.put("Musername",miwen[0]);
vars.put("Mpassword",miwen[1]);

  • 22
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
apache-jmeter-5.6.2.tgz是Apache JMeter的一个版本文件。Apache JMeter是一种用于性能测试和负载测试的开源工具。它被广泛用于测量应用程序的性能,特别是在高负载情况下的性能。该工具可以模拟多种类型的网络负载,并提供了丰富的分析和报告功能。 apache-jmeter-5.6.2.tgz是一个压缩文件,其中包含了Apache JMeter 5.6.2版本的相关代码和文件。通过下载并解压这个文件,我们可以获得最新版本的JMeter工具来进行性能测试。 apache-jmeter-5.6.2.tgz文件中的内容包括JMeter的执行文件、库文件、配置文件以及一些示例测试脚本。通过执行JMeter的执行文件,我们可以启动JMeter工具,并使用它进行各种性能测试任务。 使用apache-jmeter-5.6.2.tgz文件进行性能测试时,我们可以根据具体的需求来配置测试计划、线程组、取样器等。通过添加取样器并配置相应的参数,我们可以模拟用户在应用程序上执行的各项操作,并记录相应的响应时间和吞吐量等指标。 此外,apache-jmeter-5.6.2.tgz文件还提供了强大的插件机制,可以通过插件来扩展JMeter的功能和性能测试能力。我们可以根据需求下载并安装相应的插件,以满足更复杂的性能测试需求。 总结来说,apache-jmeter-5.6.2.tgz是Apache JMeter工具的一个版本文件,通过使用它,我们可以进行性能测试和负载测试,并通过分析和报告来评估应用程序在不同负载下的性能表现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值