我正在尝试在NodeJS和python中对base64编码二进制字符串,并且我得到了2个不同的值。
注意,值为i
是使用os.urandom(16)
在python中生成的16个随机字节
的NodeJS
> 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==
我做错了吗?它适用于常规字符串,例如我的名字。
的NodeJS
> var s = new Buffer('travis').toString('base64');
undefined
> console.log(s);
dHJhdmlz
的Python
>>> s = base64.b64encode('travis')
>>> print s
dHJhdmlz
答案 0 :(得分:9)
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。您需要告诉Buffer
将i
视为二进制代码:
> var i = '>e\x93\x10\xabK\xbe\xfeX\x97\x9a$\r\xef\x8f3';
> var s = new Buffer(i, 'binary').toString('base64');
> s
'PmWTEKtLvv5Yl5okDe+PMw=='