MD5是一种不可逆的加密算法,虽然该加密算法已经被破解,但是对于一些安全要求不是特别高的应用还是比较好的选择。若是希望安全级别更高一点的加密算法可以考虑RSA非对称加密等。
虽说不同语言的md5加密算法是一样的,但是若是不是和外部应用进行交互的话,也可以对md5进行自定义规则。以提高安全性。
一、MD5实例
public class MD5Util{
//可以约束生成的MD5是16进制或是8进制的,本文使用十六进制的
//定义16进制对应的字符数组
private static char[] chars = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9','a', 'b', 'c', 'd', 'e', 'f'};
//进行md5加密
public final static md5(String message,String key){
try{
byte[] bytes = (key+message).getBytes();
MessageDigest mdTemp = MessageDigest.getInstance("MD5");
mdTemp.update(bytes);
byte[] mdBytes = mdTemp.digest();//生成固定16长度的字节数组
int length = mdBytes.length;
//下面就是第三点可以自定义的部分,标准的如下
int j = 2;//md5最后生成的长度为j*16
char[] desChars = new char[length*j];
int k = 0;
for(int i = 0 ; i < length ; i++){
Byte byte = mdBytes[i];
//只保留byte的最后4位,定义成16进制的就要用oxf
//下面的部分也可以自定义,只要保留出4位,8进制就用07
desChars[k++] = hexDigits[byte >>> 4 & 0xf];
desChars[k++] = hexDigits[byte0 & 0xf];
}
return new String(desChars);
}catch(Exception e){}
return null;
}
}
虽说不同语言的md5加密算法是一样的,但是若是不是和外部应用进行交互的话,也可以对md5进行自定义规则。以提高安全性。
一、MD5实例
public class MD5Util{
//可以约束生成的MD5是16进制或是8进制的,本文使用十六进制的
//定义16进制对应的字符数组
private static char[] chars = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9','a', 'b', 'c', 'd', 'e', 'f'};
//进行md5加密
public final static md5(String message,String key){
try{
byte[] bytes = (key+message).getBytes();
MessageDigest mdTemp = MessageDigest.getInstance("MD5");
mdTemp.update(bytes);
byte[] mdBytes = mdTemp.digest();//生成固定16长度的字节数组
int length = mdBytes.length;
//下面就是第三点可以自定义的部分,标准的如下
int j = 2;//md5最后生成的长度为j*16
char[] desChars = new char[length*j];
int k = 0;
for(int i = 0 ; i < length ; i++){
Byte byte = mdBytes[i];
//只保留byte的最后4位,定义成16进制的就要用oxf
//下面的部分也可以自定义,只要保留出4位,8进制就用07
desChars[k++] = hexDigits[byte >>> 4 & 0xf];
desChars[k++] = hexDigits[byte0 & 0xf];
}
return new String(desChars);
}catch(Exception e){}
return null;
}
}