为什么C# md5 32位加密算法,密码明文会出现31位
原创
©著作权归作者所有:来自51CTO博客作者jdsjlzx的原创作品,请联系作者获取转载授权,否则将追究法律责任
public string returnmima(string str)
{
string ps = "";
MD5 md5 = MD5.Create();
byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(str));
for (int i = 0; i < s.Length; i++)
{
ps += s[i].ToString("x");
}
return ps;
}
这个是我的代码。
要加密的字段:1234abcd
结果为: ef73781effc577410f87fe2f437a435
但是正确应该为:ef73781effc5774100f87fe2f437a435
当中怎么多了个0,我怎么就少了个0????
这个是很常见的错误,你字节转换成字符串的时候要保证是2位宽度啊,某个字节为0转换成字符串的时候必须是00的,否则就会丢失位数啊。不仅是0,1~9也一样。
因此把那个ps += s[i].ToString("x");
改为ps += s[i].ToString("x2");
就ok了。