1、先在eclipse里面写好MD5的加密文件,用eclipse执行一遍,确保文件不会报错

 

jmeter用beanshell调用自己写的jar进行MD5加密_文件目录

Str2MD5.java 内容如下:

jmeter用beanshell调用自己写的jar进行MD5加密_参数化_02
package hehe.md5;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

public class Str2MD5 {
    
    public String MD5(String sourceStr) {
        String result = "";
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
            md.update(sourceStr.getBytes());
            byte b[] = md.digest();
            int i;
            StringBuffer buf = new StringBuffer("");
            for (int offset = 0; offset < b.length; offset++) {
                i = b[offset];
                if (i < 0)
                    i += 256;
                if (i < 16)
                    buf.append("0");
                buf.append(Integer.toHexString(i));
            }
            result = buf.toString();
            System.out.println("MD5(" + sourceStr + ",32) = " + result);
         //   System.out.println("MD5(" + sourceStr + ",16) = " + buf.toString().substring(8, 24));
        } catch (NoSuchAlgorithmException e) {
            System.out.println(e);
        }
        return result;
    }
}
jmeter用beanshell调用自己写的jar进行MD5加密_参数化_02

2、将文件导出  并放到 JM的lib/ext文件目录下

jmeter用beanshell调用自己写的jar进行MD5加密_参数化_04jmeter用beanshell调用自己写的jar进行MD5加密_java_05

3、在JM里面调用

jmeter用beanshell调用自己写的jar进行MD5加密_java_06

import hehe.md5.Str2MD5;
String res = new Str2MD5().MD5("adf");
System.out.println(res);
vars.put("md5",res.toString());

看一下结果 

jmeter用beanshell调用自己写的jar进行MD5加密_java_07

 

这样 就可以在 JM的变量里面引用啦   还可以将传参进行参数化。 其实单纯的MD5加密 在JM里面有一个函数  直接就可以调用。_MD5()