jmeter对接口测试入参进行MD5加密的5种方式

在使用jmeter作测试的过程当中,常常须要对请求的入参进行加密,下面列举几种经常使用的方法,以登陆请求密码须要MD5加密为例。html

虽然能够先把参数化的明文密码都先md5加密,而不是在登陆前先执行加密,可是实际状况是,登陆后的请求也可能有须要加密的入参,且入参是动态获取的,因此最好是在脚本运行过程当中加密,而不是提早加密好进行参数化。java

若是用户的密码都不同,就须要先对明文密码进行参数化。下面只演示单个用户请求。 python

注意:涉及路径的,路径最好参数化,不要写死git

 

jmeter自带函数

自带md5函数

在函数助手中找到__MD5这个函数,第一个参数是要md5加密的值,第二个参数是保存加密后值的变量shell

请求apache

发送请求,能够看到密码加密了eclipse

 

自带函数生成uuid

可能有些场景须要一个UUID值,即通用惟一识别码 (Universally Unique Identifier)maven

${__UUID}ide

 

beanshell自定义脚本

beanshell脚本md5加密

​细心的朋友会发现,不是每一个jmeter版本都有${__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);
    }
}

  

 

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前置处理器 

相关文章
相关标签/搜索