标签:c style class blog code java
MD5(单向散列算法)的全称是Message-Digest Algorithm 5(信息-摘要算法),经MD2、MD3和MD4发展而来。MD5算法的使用不需要支付任何版权费用。
1)比如发送一个电子文档,发送前,我先得到MD5的输出结果a。然后在对方收到电子文档后,对方也得到一个MD5的输出结果b。如果a与b一样就代表中途未被篡改。
2)比如我提供文件下载,为了防止不法分子在安装程序中添加木马,我可以在网站上公布由安装文件得到的MD5输出结果。
3)SVN在检测文件是否在CheckOut后被修改过,也是用到了MD5.
现在很多网站在数据库存储用户的密码的时候都是存储用户密码的MD5值。这样就算不法分子得到数据库的用户密码的MD5值,也无法知道用户的密码。
这需要一个第三方认证机构。例如A写了一个文件,认证机构对此文件用MD5算法产生摘要信息并做好记录。若以后A说这文件不是他写的,权威机构只需对此文件重新产生摘要信息,然后跟记录在册的摘要信息进行比对,相同的话,就证明是A写的了。这就是所谓的“数字签名”。
实用代码:
public string CalculateMd5Hash(string path) { try { var file = new FileStream(path, FileMode.Open, FileAccess.Read, FileShare.Read); var getMd5 = new System.Security.Cryptography.MD5CryptoServiceProvider(); byte[] hash_byte = getMd5.ComputeHash(file); string result = System.BitConverter.ToString(hash_byte); result = result.Replace("-", ""); return result; } catch (Exception e) { return e.ToString(); } }
标签:c style class blog code java
原文地址:http://www.cnblogs.com/pengzhen/p/3775049.html