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次,发帖成功后注销退出 ...
随机推荐
- NOI-动规题目集锦
162:Post Office 解题思路 #include<bits/stdc++.h> using namespace std; ],f[][],mi[][],i,j; int main ...
- python入门之作用域
作用域的分类 1.全局作用域 全局可以调用的名字就存在于全局作用域 内置名称空间 + 全局名称空间 2.局部作用域 局部可以调用的名字就存放于局部作用域 局部名称空间 3. global 声明全局变量 ...
- C# 杀掉系统中的进程
杀掉系统进程之前首先要知道进程名称(说了句废话),这里要注意在任务管理器中的进程名称不一定是真实的名称.打个比方,我们开启一个"记事本",任务管理器中进程名称为"记事本& ...
- [转帖]linux find -regex 使用正则表达式
linux find -regex 使用正则表达式 https://www.cnblogs.com/jiangzhaowei/p/5451173.html find之强大毋庸置疑,此处只是带领大家一窥 ...
- 转 Hystrix超时实现机制
HystrixCommand在执行的过程中如何探测超时,本篇主要对此进行介绍说明. 1.主入口:executeCommandAndObserve #com.netflix.hystrix.Abstra ...
- k8s的学习
20191123 开始重头再学一遍k8 一 K8S的组件介绍
- YAML语言简明教程
编程免不了要写配置文件,如果你还在用xml/ini/json,就有点过时了,怎么写配置也是一门学问. YAML 是专门用来写配置文件的语言,非常简洁和强大,远比 JSON 格式方便. 本文介绍 YAM ...
- Spring Security实现OAuth2.0授权服务 - 进阶版
<Spring Security实现OAuth2.0授权服务 - 基础版>介绍了如何使用Spring Security实现OAuth2.0授权和资源保护,但是使用的都是Spring Sec ...
- pands模块的妙用爬取网页中的表格
拿我这篇为例https://www.cnblogs.com/pythonywy/p/11574340.html import pandas as pd df = pd.read_html('https ...
- MySQL之查询篇(三)
一:查询 1.创建数据库,数据表 -- 创建数据库 create database python_test_1 charset=utf8; -- 使用数据库 use python_test_1; -- ...