package Utile; import java.math.BigInteger; import java.security.MessageDigest; /** * 对密码进行MD5加密的工具类 * static与非static类区别: * 非static类,别的类应用此类方法是需实例化对象,临时分配内存至JVM,会自动关闭 * static类中的方法,静态化后内存会一直分配一块空间给此类用来引用,直至程序关闭,不需实例化 * * @author Joy * */ public class MD5_Utile { //由于工具类方法不须要实例化 // 生成16位MD5密文 public static String getMD5(String c_password) { try { // 生成一个MD5加密计算摘要 MessageDigest md = MessageDigest.getInstance("MD5"); // 调用update方法计算MD5函数(参数:将密码串转换为操做系统的字节编码) md.update(c_password.getBytes()); // digest()最后返回md5的hash值,返回值为8位的字符串,但此方法要先调用update // BigInteger函数则将8位的字符串转换成16位hex值,用字符串来表示;获得字符串形式的hash值,数值从1开始 // BigInteger会把0省略掉,需补全至32位,重写一个方法将16位数转换为32位数 String md5 = new BigInteger(1, md.digest()).toString(16); return fillMD5(md5); } catch (Exception e) { throw new RuntimeException("MD5加密错误:" + e.getMessage(), e); } } // 将16位数转为32位 public static String fillMD5(String md5) { return md5.length() == 32 ? md5 : fillMD5("0" + md5); } }