日期:2014-05-19  浏览次数:20892 次

请教一个MD5加密的问题
请问MD5加密的原理是什么?在2003和2005下对同一个文件进行加密,得到的MD5校验码为什么不相同呢??

------解决方案--------------------
哈希函数将任意长度的二进制字符串映射为固定长度的小型二进制字符串。加密哈希函数有这样一个属性:在计算上不大可能找到散列为相同的值的两个不同的输入;也就是说,两组数据的哈希值仅在对应的数据也匹配时才会匹配。数据的少量更改会在哈希值中产生不可预知的大量更改。

MD5 算法的哈希值大小为 128 位。

------解决方案--------------------
MD5是摘要,不管多长的数据,得到的都是128二进制(一般用32位16进制字符串表示)

2003和2005下对同一个文件进行加密,得到的MD5校验码不相同说明有一个用的方法不对
------解决方案--------------------
using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;

public string Encrypt(string Source)
{
byte[] data = UTF8Encoding.UTF8.GetBytes(Source);
// This is one implementation of the abstract class MD5.
MD5 md5 = new MD5CryptoServiceProvider();
byte[] result = md5.ComputeHash(data);
return Convert.ToBase64String(result);

}
public byte[] Encrypt(byte[] Source)
{
MD5 md5 = new MD5CryptoServiceProvider();
byte[] result = md5.ComputeHash(Source);
return result;
}