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;
}
}
}