最近要和某公司进行系统对接,对方使用C#给出了这样一个加密函数: 1 2 3 4 5 6 7 8 public static string ( string str) { MD5 md5 = new MD5CryptoServiceProvider(); byte[] temp = System.Text.Encoding.UTF8.GetBytes(str
最近要和某公司进行系统对接,对方使用C#给出了这样一个加密函数:
首先把字符串变成字节的形式,然后再对其MD5加密,最后再BASE64加密。首先注意在Python2中中文编码是个很容易出错的地方,所以要先把字符串变成unicode形式,然后再分别对其进行encode:
从流程上看算法应该是一样的,但不知为什么得出的base64码却始终不能通过验证。不得已情况下搭建了.net开发环境后发现C#中md5加密是16位,所以在python中不要使用md5.hexdigest生成32位密文。