8

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

请注意,该值是i使用 python 生成的 16 个随机字节os.urandom(16)

节点JS

> 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==

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

节点JS

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

Python

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

1 回答 1

12

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=='
于 2013-10-01T20:29:31.397 回答