MD5加密算法,即"Message-Digest Algorithm 5(信息-摘要算法)",它由MD2、MD3、MD4发展而来的一种单向函数算法(也就是HASH算法),它是国际著名的公钥加密算法标准RSA的第一设计者R.Rivest于上个世纪90年代初开发出来的。MD5的最大作用在于,将不同格式的大容量文件信息在用数字签名软件来签署私人密钥前"压缩"成一种保密的格式,关键之处在于——这种"压缩"是不可逆的。 Java JDK已经自带了MD5的实现,只要简单调用下就可以。
MD5,其实就是一中算法。可以将一个字符串,或文件,或压缩包,执行md5后,就可以生成一个固定长度为128bit的串。这个串,基本上是唯一的。
MD5较老,散列长度通常为128位,随着计算机运算能力提高,找到“碰撞”是可能的。因此,在安全要求高的场合不使用MD5。
java使用代码:
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException; public class CreateMD5 {
public static String getMd5(String plainTest){
try{
MessageDigest md = MessageDigest.getInstance("md5");
byte[] input = plainTest.getBytes();
md.update(input);
byte[] b = md.digest(); int i; StringBuffer sb = new StringBuffer();
for(int k=0;k<b.length;k++){
i=b[k];
if(i<0){
i+=256;
}
if(i<16){
sb.append("0");
}
sb.append(Integer.toHexString(i));
}
//32位加密
return sb.toString();
//16位加密
//return sb.toString().substring(8, 24); }catch(NoSuchAlgorithmException e){
e.printStackTrace();
return null;
}
} public static void main(String[] args){
System.out.println(CreateMD5.getMd5("hello world"));
}
}