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

相關文章
相關標籤/搜索