最近要和某公司进行系统对接,对方使用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); byte[] MD5 = md5.ComputeHash(System.Text.Encoding.UTF8.GetBytes(str)); string result = Convert.ToBase64String(MD5, 0, MD5.Length); return result; }
|
首先把字符串变成字节的形式,然后再对其MD5加密,最后再BASE64加密。首先注意在Python2中中文编码是个很容易出错的地方,所以要先把字符串变成unicode形式,然后再分别对其进行encode:
大专栏 python中的md5以及base64加密">1 2 3 4 5 6 7 8 9 10 11 12
|
import hashlib import base64 def getcode(unicxml): '''根据拼接后的XML生成校验码 XML需要是unicode ''' temp = unicxml.encode("utf-8") md5 = hashlib.md5() md5.update(temp) md5str = md5.digest() b64str = base64.b64encode(md5str) return b64str
|
从流程上看算法应该是一样的,但不知为什么得出的base64码却始终不能通过验证。不得已情况下搭建了.net开发环境后发现C#中md5加密是16位,所以在python中不要使用md5.hexdigest生成32位密文。