为什么md5 c#32位加密算法,密码明文会出现31位

来源:互联网 发布:阿里云服务器内存不足 编辑:程序博客网 时间:2024/05/21 09:21
原帖地址:http://zhidao.baidu.com/question/87806935.html
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了。
原创粉丝点击