MD5 加密的工具类,提供了对字符串进行 MD5 加密的功能。主要包括以下几个方法:
md5(String s)
:对传入的字符串进行 MD5 加密,并返回加密后的字节数组。toHex(byte hash[])
:将字节数组转换为十六进制字符串表示。hash(String s)
:对传入的字符串进行 MD5 加密,并返回加密后的字符串表示。
在 md5
方法中,首先使用 MessageDigest.getInstance("MD5")
获取 MD5 加密算法实例,然后根据 UTF-8 编码将输入字符串进行加密,并返回加密后的字节数组。
toHex
方法将字节数组转换为对应的十六进制字符串表示,并返回。
hash
方法是对外暴露的接口,调用了 md5
方法进行加密,然后将得到的字节数组转换为字符串表示,并返回。
这个工具类可以方便地对字符串进行 MD5 加密,适用于需要对数据进行加密处理的场景。
package com.muyuan.common.utils.sign;import java.security.MessageDigest;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;/*** Md5加密方法* * */
public class Md5Utils
{private static final Logger log = LoggerFactory.getLogger(Md5Utils.class);private static byte[] md5(String s){MessageDigest algorithm;try{algorithm = MessageDigest.getInstance("MD5");algorithm.reset();algorithm.update(s.getBytes("UTF-8"));byte[] messageDigest = algorithm.digest();return messageDigest;}catch (Exception e){log.error("MD5 Error...", e);}return null;}private static final String toHex(byte hash[]){if (hash == null){return null;}StringBuffer buf = new StringBuffer(hash.length * 2);int i;for (i = 0; i < hash.length; i++){if ((hash[i] & 0xff) < 0x10){buf.append("0");}buf.append(Long.toString(hash[i] & 0xff, 16));}return buf.toString();}public static String hash(String s){try{return new String(toHex(md5(s)).getBytes("UTF-8"), "UTF-8");}catch (Exception e){log.error("not supported charset...{}", e);return s;}}
}