欢迎加入U3D交流群,群号码:308093702~~~~
数据经过网络传输后会变得非常不安全,很容易被拦截改动,最简单有效的校验方式是使用MD5验证。首先要给数据加一个密匙,然后使用MD5算法算出校验码,服务器收到客户端的数据后,使用密匙再次进行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,使用MD5算出32位的校验码字符串。
string data="hello,world";
string key="123";
Md5Sum(data+key);//a3886a8079dd5fa34995a6434b72932a