jmeter对接口测试入参进行MD5加密的5种方式
在使用jmeter做测试的过程中,经常需要对请求的入参进行加密,下面列举几种常用的方法,以登录请求密码需要MD5加密为例。
虽然可以先把参数化的明文密码都先md5加密,而不是在登录前先执行加密,但是实际情况是,登录后的请求也可能有需要加密的入参,且入参是动态获取的,所以最好是在脚本运行过程中加密,而不是提前加密好进行参数化。
如果用户的密码都不一样,就需要先对明文密码进行参数化。下面只演示单个用户请求。
注意:涉及路径的,路径最好参数化,不要写死
jmeter自带函数
自带md5函数
在函数助手中找到__MD5这个函数,第一个参数是要md5加密的值,第二个参数是保存加密后值的变量

请求

发送请求,可以看到密码加密了

自带digest
新版本的jmeter中,已经没有md5函数了,官网:https://jmeter.apache.org/usermanual/functions.html
取而代之的是digest,digest函数返回指定哈希算法中的摘要值


参数含义:
算法摘要:MD2、MD5、SHA-1、SHA-224、SHA-256、SHA-384、SHA-512
String to be hashed:要计算的字符串;
Salt to be used for hashing (optional):用于计算散列的盐(可选项);
Upper case result, defaults to false (optional):结果大写,默认为false(可选),即默认摘要值为小写
存储结果的变量名(可选)
实例:MD5加密123456

复制上面的结果

可以看到,请求的密码加密了,和上面的加密结果一致
自带函数生成uuid
可能有些场景需要一个UUID值,即通用唯一识别码 (Universally Unique Identifier)
${__UUID}
beanshell自定义脚本(*)
beanshell脚本md5加密
在jmeter的lib目录下,自带commons-codec-1.11.jar(如果没有,可以到maven库下一个,下载地址:https://mvnrepository.com/,然后放到jmeter的lib目录下),所以,可以借助apache工具类DigestUtils实现。
beanshell脚本
import org.apache.commons.codec.digest.DigestUtils;
String password_md5 = DigestUtils.md5Hex("123456");
vars.put("password_md5", password_md5);
解释:
第一行:导包
第二行:加密
第三行:将加密后的值放到变量中
也可以把密码全部转为大写或者小写:
password_md5.toUpperCase()
password_md5.toLowerCase()

引用变量

发送请求,可以看到密码加密了

也可以用beanshell前置处理器,结果是一样的

beanshell脚本生成uuid

3个线程,运行2次

可以看到,生成的UUID都不一样

引用外部java文件
这里我们还是用上一种方法用到的jar包。
pom中添加依赖
<!-- https://mvnrepository.com/artifact/commons-codec/commons-codec -->
<dependency>
<groupId>commons-codec</groupId>
<artifactId>commons-codec</artifactId>
<version>1.12</version>
</dependency>
编写java代码
package com.uncleyong; import org.apache.commons.codec.digest.DigestUtils; /**
* @Time : 2019/9/1 10:52
* @description:
* @公众号 : 全栈测试笔记
* @Blog : http://www.cnblogs.com/uncleyong
* @Gitee : https://gitee.com/uncleyong
*/ public class MD5Util {
// 借助apache工具类DigestUtils实现
public static String encryptToMD5(String str){
return DigestUtils.md5Hex(str);
}
public static void main(String[] args) {
String res = encryptToMD5("123456");
System.out.println(res);
}
}

DigestUtils类


beanshell引入java文件、调用加密方法、把加密后的值放到变量中
source()读一个bsh脚本到当前解释器(interpreter)中,或者在新的解释器中运行这个脚本。注意:路径最好参数化,不要写死
source("E:\\uncleyong\\javatest\\src\\main\\java\\com\\uncleyong\\MD5Util.java");
String password_md5 = new MD5Util().encryptToMD5("123456");
vars.put("password_md5", password_md5);

引用变量

发送请求,可以看到密码加密了

引用外部class文件
引用class文件的方式,和引用java文件类似,沿用上一方法创建的maven工程,项目运行后,在左侧会生成target目录,在这个目录下,可以看到我们的包名及生成的class文件,我们需要引用这个文件
beanshell中引入类文件
注意:类文件路径不能包含包名对应的目录路径,否则会报错。添加com的父级目录路径即可。注意:路径最好参数化,不要写死
addClassPath("E:\\uncleyong\\javatest\\target\\classes\\");
import com.uncleyong.MD5Util;
String password_md5 = new MD5Util().encryptToMD5("123456");
vars.put("password_md5", password_md5);

addClassPath("E:\\uncleyong\\javatest\\target\\classes\\");
import com.uncleyong.MD5Util;
public static void fun(){
String password_md5 = new MD5Util().encryptToMD5("123456");
vars.put("password_md5", password_md5);
}
fun();

引用变量

发送请求,可以看到密码加密了

引用外部jar文件(推荐)
如果在beanshell中写复杂的逻辑代码,出错了,定位很不方便,所以,如果代码逻辑复杂,建议在idea或者eclipse中写好,
然后mvn package打包,生成的target目录下,会有一个jar包,把生成的jar包复制到lib下ext中引入jar包(jmeter引入jar包的3种方式:https://www.cnblogs.com/uncleyong/p/11475577.html),重启jmeter
这样我们只需要在beanshell中写很少的脚本,这也是5种方式中我极力推荐使用的方式。
继续沿用之前创建的maven项目(我们可以在idea中写比较复杂的代码,这里只是演示,所以只是很简单的代码)
类名调用静态方法
import com.uncleyong.MD5Util;
String password_md5 = MD5Util.encryptToMD5("123456");
vars.put("password_md5", password_md5);

实例调用静态方法
import com.uncleyong.MD5Util;
String password_md5 = new MD5Util().encryptToMD5("123456");
vars.put("password_md5", password_md5);

引用变量

发送请求,可以看到密码加密了

也可以用beanshell前置处理器

jmeter实现sha256算法加密
参考:https://www.cnblogs.com/uncleyong/p/12765569.html
jmeter对接口测试入参进行MD5加密的5种方式的更多相关文章
- java 实现md5加密的三种方式与解密
java 实现md5加密的三种方式 CreateTime--2018年5月31日15点04分 Author:Marydon 一.解密 说明:截止文章发布,Java没有实现解密,但是已有网站可以免费 ...
- 对称加密——对入参进行DES加密处理
体验更优排版请移步原文:http://blog.kwin.wang/programming/symmetric-encryption-des-js-java.html 对称加密是最快速.最简单的一种加 ...
- 对Java代码加密的两种方式,防止反编译
使用Virbox Protector对Java项目加密有两种方式,一种是对War包加密,一种是对Jar包加密.Virbox Protector支持这两种文件格式加密,可以加密用于解析class文件的j ...
- app逆向万能的md5加密hook破解入参方法(其他加密用通用方法原理差不多,小白推荐)
一.原理 安卓开发调用md5加密时候都会调用到系统类java.security.MessageDigest 加密时候会会调用里面2个关键方法update以及digest 根据这个原理我们开始写代码吧 ...
- PHP 加密的几种方式
在使用PHP开发Web应用的中,很多的应用都会要求用户注册,而注册的时候就需要我们对用户的信息进行处理了,最常见的莫过于就是邮箱和密码了,本文意在讨论对密码的处理:也就是对密码的加密处理. MD5 相 ...
- python进行md5加密的两种方法
本文转自:https://www.cnblogs.com/zknublx/p/6212590.html 一. 使用md5包 import md5 src = 'this is a md5 test.' ...
- MD5 加密的两种方法
System.Security.Cryptography.MD5CryptoServiceProvider md5 = new System.Security.Cryptography.MD5Cryp ...
- jmeter md5加密请求参数
实际的接口测试过程中,再发生http之前有可能需要对某些参数(或某几个参数的组合)进行md5加密 在jmeter中可通过两种方式来实现md5加密 beanshell实现md5加密 在org.apach ...
- jmeter-01 JMeter HTTP测试的各元件功能演示示例
最小的测试将包括测试计划,线程组和一个或多个采样器. Jmeter HTTP测试的各元件演示示例 功能逻辑:wap官网(a.4399sy.com.hk),每个用户登录一次,发帖2次,发帖成功后注销退出 ...
随机推荐
- IO流一些问题的总结
字节流的继承体系 字符流的继承体系 字符编码是什么?常见的字符编码表有哪些? 字符编码(英语:Character encoding)也称字集码,是把字符集中的字符编码为指定集合中某一对象,以便文本在计 ...
- AKKA Router路由
路由概念 大量的actor在并行工作的时候,处理到来的消息流,这时候就需要一个组件或者东西来引导消息从源到目的地Actor,这个组件或者东西就是Router在Akka中,router也是一种actor ...
- JDBC链接数据库MySQL 8.0 Public Key Retrieval is not allowed 错误的解决方法
现象 Mybatis和Spring框架整合过程中报 com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Publ ...
- spring Valid @Pattern 常见的验证表达式
1 匹配首尾空格的正则表达式:(^\s*)|(\s*$) 2 整数或者小数:^[0-9]+\.{0,1}[0-9]{0,2}$ 3 只能输入数字:"^[0-9]*$". 4 只 ...
- pip install 时报错 pip is configured with locations that require TLS/SSL, however the ssl module in Python is not available.
pip install 时报错: pip is configured with locations that require TLS/SSL, however the ssl module in Py ...
- day60——单表操作补充(批量插入、查询、表结构)
day60 批量插入(bulk_create) # bulk_create obj_list = [] for i in range(20): obj = models.Book( title=f'金 ...
- mysql—增删改查
MySQL数据库,每条命令后要加:号.不然会认为命令语句未输入完, 若在语句结尾不添加分号时, 命令提示符会以 -> 提示你继续输入(有个别特例, 但加分号是一定不会错的); show data ...
- MQTTv5.0 ---AUTH – 认证交换
AUTH报文被从客户端发送给服务端,或从服务端发送给客户端,作为扩展认证交换的一部分,比如质询/ 响应认证.如果CONNECT报文不包含相同的认证方法,则客户端或服务端发送AUTH报文将造成协议错 误 ...
- 使用Docker安装mysql,挂载外部配置和数据
.挂载外部配置和数据安装 mkdir /opt mkdir /opt/mysql mkdir /opt/mysql/conf.d mkdir /opt/mysql/data/ 创建my.cnf配置文件 ...
- Tomcat 中的 Session 和 Cookie
HTTP 是一种无状态通信协议,每个请求之间相互独立,服务器不能识别曾经来过的请求.而对于 Web 应用,它的活动都是依赖某个状态的,比如用户登录,此时使用 HTTP 就需要它在一次登录请求后,有为后 ...