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

 

 posted on 2016-06-12 22:04  Marval  阅读(1270)  评论(0编辑  收藏  举报