MD5

作者: Mango_lxh | 来源:发表于2018-09-27 22:06 被阅读0次

    参考链接
    https://www.cnblogs.com/second-tomorrow/p/9129043.html

    Message Digest Algorithm [MD5])(中文名为消息摘要[算法])

    什么是md5加密?

    MD5将任意长度的“字节串”变换成一个128bit的大整数,并且它是一个不可逆的字符串变换算法,换句话说就是,即使你看到源程序和算法描述,也无法将一个MD5的值变换回原始的字符串,从数学原理上说,是因为原始的字符串有无穷多个,这有点象不存在反函数的数学函数

    MD5的典型应用是对一段Message(字节串)产生fingerprint(指纹),以防止被“篡改”。举个例子,你将一段话写在一个叫readme.txt文件中,并对这个readme.txt产生一个MD5的值并记录在案,然后你可以传播这个文件给别人,别人如果修改了文件中的任何内容,你对这个文件重新计算MD5时就会发现。如果再有一个第三方的认证机构,用MD5还可以防止文件作者的“抵赖”,这就是所谓的数字签名应用。

    java实现md5加密

        package com.cx.bank.util;
        public class MD5
        {
              public String encode(byte[] source) {  
                String s = null;  
                char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };  
                try {  
                    java.security.MessageDigest md = java.security.MessageDigest.getInstance("MD5");  
                    md.update(source);  
                    byte tmp[] = md.digest();   
                    char str[] = new char[16 * 2];   
                    int k = 0;   
                    for (int i = 0; i < 16; i++) {   
                        byte byte0 = tmp[i];   
                        str[k++] = hexDigits[byte0 >>> 4 & 0xf];   
                        str[k++] = hexDigits[byte0 & 0xf];   
                    }  
                    s = new String(str);   
                } catch (Exception e) {  
                    e.printStackTrace();  
                }  
                return s;  
            }  
              
            public String getMD5(String source) {  
                return (source == null || "".equals(source)) ? "" : encode(source.getBytes());  
            }  
        }
    

    相关文章

      网友评论

          本文标题:MD5

          本文链接:https://www.haomeiwen.com/subject/phbyoftx.html