MD5简讲以及细讲

MD5是什么

message-digest algorithm 5(信息-摘要算法)。经常说的“MD5加密”,就是它→信息-摘要算法。

在下载一下东西时,经常在一些压缩包属性里,看到md5值。而且这个下载页面,很可能会在某一个地方,写了一句,此文件的MD5值为XXXXXXXXX。这有什么作用呢?

白话白话:md5,其实就是一中算法。可以将一个字符串,或文件,或压缩包,执行md5后,就可以生成一个固定长度为128bit的串。这个串,基本上是唯一的。

所以,有人修过压缩包后,就会生成新的串,这时就可以拿网站提供的串和新生成的串对比,如果不同,那就是被人修过过了。

 

加密和摘要,是不一样的

加密后的消息是完整的;具有解密算法,得到原始数据;

摘要得到的消息是不完整的;通过摘要的数据,不能得到原始数据;

所以,当看到很多人说,md5,加密,解密的时候,呵呵一笑就好了。

QQ截图20150311162809

 

MD5长度

有人说md5,128位,32位,16位,到底md5多长?

md5的长度,默认为128bit,也就是128个0和1的二进制串。

这样表达是很不友好的。

所以将二进制转成了16进制,每4个bit表示一个16进制,

所以128/4 = 32 换成16进制表示后,为32位了。

QQ截图20150305111855

 

为什么网上还有md5是16位的呢?

网上有很多帖子,md5 32位 16位 加密 区别。

仔细观察admin生成的32位和16位的md5值……

查询结果:

md5(admin,32) = 21232f297a57a5a743894a0e4a801fc3

md5(admin,16) = 7a57a5a743894a0e

看出来了吧!

其实16位的长度,是从32位md5值来的。是将32位md5去掉前八位,去掉后八位得到的。

 

MD5的作用

①一致性检验,最上面那个例子

②数字签名,还是最上面那个例子。只是把md5看出了一个指纹,按了个手印说明独一无二了。

③安全访问认证,这个就是平时系统设计的问题了。

在用户注册时,会将密码进行md5加密,存到数据库中。这样可以防止那些可以看到数据库数据的人,恶意操作了。

 

md5不能破解吗?

md5是不可逆的,也就是没有对应的算法,从生产的md5值逆向得到原始数据。

但是如果使用暴力破解,那就另说了。

 

md5是唯一的吗?

md5作为数据库中的主键可行吗?这就涉及到一个问题,md5值是唯一的吗?答案是,不唯一。

也就是一个原始数据,只对应一个md5值;

但是一个md5值,可能对应多个原始数据。

 

java中生成MD5的值

  1. import java.security.MessageDigest;  
  2. public class MD5Util {  
  3.     public final static String MD5(String s) {  
  4.         char hexDigits[] = { '0', '1', '2', '3', '4',  
  5.                              '5', '6', '7', '8', '9',  
  6.                              'A', 'B', 'C', 'D', 'E', 'F' };  
  7.         try {  
  8.             byte[] btInput = s.getBytes();  
  9.      //获得MD5摘要算法的 MessageDigest 对象  
  10.             MessageDigest mdInst = MessageDigest.getInstance("MD5");  
  11.      //使用指定的字节更新摘要  
  12.             mdInst.update(btInput);  
  13.      //获得密文  
  14.             byte[] md = mdInst.digest();  
  15.      //把密文转换成十六进制的字符串形式  
  16.             int j = md.length;  
  17.             char str[] = new char[j * 2];  //这里转成十六进制,一个中文字符占2个字节,一个英文字符占一个字节
  18.             int k = 0;  
  19.     //重点:
  20.             for (int i = 0; i < j; i++) {  
  21.                 byte byte0 = md[i];  
  22.                 str[k++] = hexDigits[byte0 >>> 4 & 0xf]; //hexDigits:将每一个密文转换成字符 
  23.                 str[k++] = hexDigits[byte0 & 0xf];  
  24.             }  
  25.             return new String(str);  
  26.         }  
  27.         catch (Exception e) {  
  28.             e.printStackTrace();  
  29.             return null;  
  30.         }  
  31.     }  
  32.     public static void main(String[] args) {  
  33.         System.out.print(MD5Util.MD5("password"));  
  34.     }  
  35. }  

 

参考:

http://www.weixuehao.com/archives/474

http://blog.csdn.net/zhyl8157121/article/details/7917744

以上是简讲,细讲请参考(以后探究)

http://blog.sina.com.cn/s/blog_6fe0eb1901014cpl.html

posted @ 2015-09-17 18:05  Code脚小Boy  阅读(143)  评论(0)    收藏  举报