加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python中的md5以及base64加密

发布时间:2020-12-20 10:16:41 所属栏目:Python 来源:网络整理
导读:最近要和某公司进行系统对接,对方使用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.ComputeHa

最近要和某公司进行系统对接,对方使用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);//Base64
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() # 16位
b64str = base64.b64encode(md5str)
return b64str

从流程上看算法应该是一样的,但不知为什么得出的base64码却始终不能通过验证。不得已情况下搭建了.net开发环境后发现C#中md5加密是16位,所以在python中不要使用md5.hexdigest生成32位密文。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读