我尝试用NodeJS和python对一个二进制字符串进行base64编码,我得到了两个不同的值。
请注意,值为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
发布于 2013-10-02 04:29:31
NodeJS正在对字符串的UTF8表示形式进行编码。Python正在对字节字符串进行编码。
在Python中,您必须执行以下操作:
>>> i = u'>e\x93\x10\xabK\xbe\xfeX\x97\x9a$\r\xef\x8f3'
>>> i.encode('utf8').encode('base64')
'PmXCkxDCq0vCvsO+WMKXwpokDcOvwo8z\n'
以获得相同的输出。
您使用默认编码创建了buffer,这意味着它一开始就将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=='
https://stackoverflow.com/questions/19125233
复制相似问题