孙广东 2014.6.24
数据经网络传输后会变得非常不安全,最简单有效的解决方案是给数据加一个密钥,使用MD5 算法算出校验码,服务器收到数据和校验码后在进行比较校验码是否正确,以此来判断数据是否修改过。 PHP生成 的 MD5 校验默认为32位的字符串, 而C#默认的是16位的字节数组,需要略加修改,转为32个字节的字符串,代码如下:
public static string Md5Sum(string strToEncrypt) { // 将需要加密的字符串转为byte数组 byte[] bs = UTF8Encoding.UTF8.GetBytes(strToEncrypt); // 创建md5 对象 System.Security.Cryptography.MD5 md5; md5 = System.Security.Cryptography.MD5CryptoServiceProvider.Create(); // 生成16位的二进制校验码 byte[] hashBytes = md5.ComputeHash(bs); // 转为32位字符串 string hashString = ""; for (int i = 0; i < hashBytes.Length; i++) { hashString += System.Convert.ToString(hashBytes[i], 16).PadLeft(2, ‘0‘); } return hashString.PadLeft(32, ‘0‘); }
使用这个 MD5 函数非常简单, 在下面的代码示例中,数据是包含有 “hello world” 的一个字符串, 密钥位123, 使用Md5Sum算出32位的校验码字符串。
string data = "hello world"; string key = "123"; Md5Sum(data + key); // 返回
原文地址:http://blog.csdn.net/u010019717/article/details/46627941