java加密算法之MD5篇
Posted lwx-apollo
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java加密算法之MD5篇相关的知识,希望对你有一定的参考价值。
字符串转MD5
public static String toMD5(String str)
MessageDigest messagedigest;
try
messagedigest = MessageDigest.getInstance("MD5");
messagedigest.update(str.getBytes("UTF-8"));
return bufferToHex(messagedigest.digest()).toUpperCase();
catch (Exception e)
e.printStackTrace();
return null;
对象转MD5
public static String toMD5(Object obj)
String resultString = null;
try
MessageDigest md = MessageDigest.getInstance("MD5");
resultString = byteToString(md.digest(JsonUtils.toJson(obj).getBytes())).toUpperCase();
catch (NoSuchAlgorithmException ex)
ex.printStackTrace();
return resultString;
测试
public static void main(String[] args)
String str = toMD5("test");
System.out.println("There is string md5 value :" + str);
Map<String,Object> obj = new HashMap<>();
obj.put("param1","param1");
String object = toMD5(obj);
System.out.println("There is object md5 value :" + object);
测试结果
全代码
public class MD5Utils
private static char md5Chars[] =
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd',
'e', 'f';
private final static String[] STR_DIGITS = "0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "a", "b", "c", "d", "e", "f";
private static String bufferToHex(byte bytes[])
return bufferToHex(bytes, 0, bytes.length);
private static String bufferToHex(byte bytes[], int m, int n)
StringBuffer stringbuffer = new StringBuffer(2 * n);
int k = m + n;
for (int l = m; l < k; l++)
appendHexPair(bytes[l], stringbuffer);
return stringbuffer.toString();
private static void appendHexPair(byte bt, StringBuffer stringbuffer)
char c0 = md5Chars[(bt & 0xf0) >> 4];
char c1 = md5Chars[bt & 0xf];
stringbuffer.append(c0);
stringbuffer.append(c1);
public static String toMD5(String str)
MessageDigest messagedigest;
try
messagedigest = MessageDigest.getInstance("MD5");
messagedigest.update(str.getBytes("UTF-8"));
return bufferToHex(messagedigest.digest()).toUpperCase();
catch (Exception e)
e.printStackTrace();
return null;
public static String toMD5(Object obj)
String resultString = null;
try
MessageDigest md = MessageDigest.getInstance("MD5");
resultString = byteToString(md.digest(JsonUtils.toJson(obj).getBytes())).toUpperCase();
catch (NoSuchAlgorithmException ex)
ex.printStackTrace();
return resultString;
private static String byteToArrayString(byte bByte)
int iRet = bByte;
if (iRet < 0)
iRet += 256;
int iD1 = iRet / 16;
int iD2 = iRet % 16;
return STR_DIGITS[iD1] + STR_DIGITS[iD2];
private static String byteToString(byte[] bByte)
StringBuffer sBuffer = new StringBuffer();
for (int i = 0; i < bByte.length; i++)
sBuffer.append(byteToArrayString(bByte[i]));
return sBuffer.toString();
public static void main(String[] args)
String str = toMD5("test");
System.out.println("There is string md5 value :" + str);
Map<String,Object> obj = new HashMap<>();
obj.put("param1","param1");
String object = toMD5(obj);
System.out.println("There is object md5 value :" + object);
以上是关于java加密算法之MD5篇的主要内容,如果未能解决你的问题,请参考以下文章
password学4——Java 加密解密之消息摘要算法(MD5 SHA MAC)