gpt4 book ai didi

python - base64 编码二进制字符串在 NodeJS 和 Python 中返回不同的值

转载 作者:太空狗 更新时间:2023-10-30 00:45:23 24 4
gpt4 key购买 nike

我正在尝试在 NodeJS 和 python 中对二进制字符串进行 base64 编码,我得到了 2 个不同的值。

注意值为i是在 python 中使用 os.urandom(16) 生成的 16 个随机字节

Node

> var i = '>e\x93\x10\xabK\xbe\xfeX\x97\x9a$\r\xef\x8f3';
> var s = new Buffer(i).toString('base64');
> console.log(s);
PmXCkxDCq0vCvsO+WMKXwpokDcOvwo8z

python

>>> import base64
>>> i = '>e\x93\x10\xabK\xbe\xfeX\x97\x9a$\r\xef\x8f3'
>>> s = base64.b64encode(i)
>>> print s
PmWTEKtLvv5Yl5okDe+PMw==

我做错了什么吗?它确实适用于常规字符串,例如我的名字。

Node

> var s = new Buffer('travis').toString('base64');
undefined
> console.log(s);
dHJhdmlz

python

>>> s = base64.b64encode('travis')
>>> print s
dHJhdmlz

最佳答案

NodeJS 正在对字符串的 UTF-8 表示进行编码。 Python 正在对字节字符串进行编码。

在 Python 中,你必须这样做:

>>> i = u'>e\x93\x10\xabK\xbe\xfeX\x97\x9a$\r\xef\x8f3'
>>> i.encode('utf8').encode('base64')
'PmXCkxDCq0vCvsO+WMKXwpokDcOvwo8z\n'

得到相同的输出。

您使用默认编码创建了缓冲区,这意味着它首先将 i 解释为 UTF-8。您需要告诉 Bufferi 视为二进制:

> var i = '>e\x93\x10\xabK\xbe\xfeX\x97\x9a$\r\xef\x8f3';
> var s = new Buffer(i, 'binary').toString('base64');
> s
'PmWTEKtLvv5Yl5okDe+PMw=='

关于python - base64 编码二进制字符串在 NodeJS 和 Python 中返回不同的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19125233/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com