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

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了。

上一篇:【Linux网络编程】因特网的IP协议是不可靠无连接的,那为什么当初不直接把它设计为可靠的?


下一篇:SpringBoot如何整合Redis(单机版)? | 带你读《SpringBoot实战教程》之三十二