Python 3 Base64 解码弄乱换行符

Python 3 Base64 decode messing up newline characters

我试图通过标准 python 库解码一个 base64 多行文件,但是只有第一行被解码,其余的被无缘无故地转储。

这是为什么?

编码前的文件(解码后我想达到的效果):

dataFile.dat

VERSION: BenWin+ Version: 3.0.12.1[CR]

[CR][LF]

CREATED: 01 September 2016 12:56:27 PM[CR]

[CR][LF]

TIME CODE: 0x907e0, 0x10004, 0x38000c, 0x242001b[CR]

[CR][LF]

...

[CR]和[LF]分别是CarriageReturn(\r)和Line Feed(\n)的字符编码

我使用 base64.b64encode 对文件进行 base64 编码,稍后想对其进行解码。这是我的代码片段。

encodedData = b'VkVSU0lPTjogQmVuV2luKyBWZXJzaW9uOiAzLjAuMTIuMQo=Cg==Q1JFQVRFRDogMDEgU2VwdGVtYmVyIDIwMTYgMTI6NTY6MjcgUE0KCg==VElNRSBDT0RFOiAweDkwN2UwLCAweDEwMDA0LCAweDM4MDAwYywgMHgyNDIwMDFiCg==Cg=='

data = base64.b64decode(encodedData)
print(data)

哪个returns

b'VERSION: BenWin+ Version: 3.0.12.1\n'

提前致谢。 使用 Python 3.5

问题似乎是您分别对每一行进行编码,然后将这些编码字符串连接在一起。 Base-64 编码的字符串可能以填充字符结尾,当解码器看到这些填充字符时,它会假定这是有效数据的结尾,因此忽略任何后续数据。

下面介绍如何对多行文本进行Base64编码Python 3.首先,我们需要将Unicode文本转换为字节。然后我们一次性对所有这些字节进行 Base64 编码。要解码,我们将过程逆向进行:首先进行 Base64 解码,然后将生成的字节解码为 Unicode 字符串。请注意 \r\n 已正确保留。

import base64

s = 'VERSION: BenWin+ Version: 3.0.12.1\r\r\nCREATED: 01 September 2016 12:56:27 PM\r\r\nTIME CODE: 0x907e0, 0x10004, 0x38000c, 0x242001b\r\r\n'
print(s)

b = base64.b64encode(s.encode('utf8'))
print(b)

z = base64.b64decode(b).decode('utf8')
print(repr(z))

输出

VERSION: BenWin+ Version: 3.0.12.1
CREATED: 01 September 2016 12:56:27 PM
TIME CODE: 0x907e0, 0x10004, 0x38000c, 0x242001b

b'VkVSU0lPTjogQmVuV2luKyBWZXJzaW9uOiAzLjAuMTIuMQ0NCkNSRUFURUQ6IDAxIFNlcHRlbWJlciAyMDE2IDEyOjU2OjI3IFBNDQ0KVElNRSBDT0RFOiAweDkwN2UwLCAweDEwMDA0LCAweDM4MDAwYywgMHgyNDIwMDFiDQ0K'
'VERSION: BenWin+ Version: 3.0.12.1\r\r\nCREATED: 01 September 2016 12:56:27 PM\r\r\nTIME CODE: 0x907e0, 0x10004, 0x38000c, 0x242001b\r\r\n'