所有加密使用的= =最后一个

时间:2015-12-10 20:51:48

标签: encryption base64

我知道大多数base64编码最后都有==。有没有其他用途做同样的事情? 例如,我发现了这个

nijdRcCHIUnketWzFbcxmvqQKKDnFW05LSE3ttTjoqyBna7JT87AwxeKdoOszXYODMRm6UfA8jK97qgV8A ==

但它不是base64类型。还有什么呢?

1 个答案:

答案 0 :(得分:9)

您发布的字符串是有效的Base64字符串。

当且仅当它编码的字节数mod 3等于1时,Base64字符串将以==结束。

>>> for i in range(10):
...   print(i, base64.b64encode(b"\x00"*i))
... 
0 b''
1 b'AA=='
2 b'AAA='
3 b'AAAA'
4 b'AAAAAA=='
5 b'AAAAAAA='
6 b'AAAAAAAA'
7 b'AAAAAAAAAA=='
8 b'AAAAAAAAAAA='
9 b'AAAAAAAAAAAA'

你看到了模式吗?

16字节(128位)加密密钥通常在Base64中编码,并且由于16 mod 3 = 1,它们的编码将以==结束。但你的字符串,解码后,长度为61个字节(488位)。这太大了,无法成为大多数加密密钥,而 small 也是RSA密钥。

这是你的字符串,已解码,然后是hexdumped:

00000000  9e 28 dd 45 c0 87 21 49  e4 7a d5 b3 15 b7 31 9a  |.(.E..!I.z....1.|
00000010  fa 90 28 a0 e7 15 6d 39  2d 21 37 b6 d4 e3 a2 ac  |..(...m9-!7.....|
00000020  81 9d ae c9 4f ce c0 c3  17 8a 76 83 ac cd 76 0e  |....O.....v...v.|
00000030  0c c4 66 e9 47 c0 f2 32  bd ee a8 15 f0           |..f.G..2.....|
0000003d

我在那里看不到任何东西告诉我它到底是什么,而file(1)也是难过的。它可能随机足以加密,但我无法通过眼睛确定。 (如果它 随机,那并不意味着它是加密的!它可能只是随机数生成器的输出。)

了解 Base64不是加密非常重要,因为它没有密钥。我不需要知道或猜测任何秘密信息来反转字符串的Base64编码。 (术语'编码'可能令人困惑 - 它更通用.UTF-8,Base64和DEFLATE都是编码,AES-CBC也是如此,但所有它们,只有AES-CBC是加密。)