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