如何解决如何将Python二进制转换为ASCII
res = ''.join(format(ord(i),'b') for i in s)
如何解密?
我尝试了以下操作,但是字符串为空?
for i in s:
res += chr(int(str(i),2))
print(res)
解决方法
在编码为二进制时,请使用'07b'或'08b'格式,因为它将保留前导零并以7或8位表示数字,这将使解码变得容易。现在我们将一次考虑8位,因为现在每个字符都以8位表示。如果您碰巧使用格式为'07b'的话,请在各处使用7。 ASCII字符需要7位才能表示。
>>> s = "abcde"
>>> res = ''.join(format(ord(i),'08b') for i in s)
>>> ans = []
>>> for i in range(0,len(res),8):
... ans.append(chr(int(res[i:i+8],2)))
...
>>> ''.join(ans)
'abcde'
一个衬里:
>>> ''.join([ chr(int(res[i:i+8],2)) for i in range(0,8)])
'abcde'
参考:
Convert to binary and keep leading zeros in Python
,您的方法行不通。您要做的就是将加密字符串的1和0转换为\x01
和\x00
字节,这两个字节均不可打印。
无论如何,这并不是真正的加密。这只是一种有缺陷的二进制编码,其中不同的输入可以为您提供相同的输出:
encode('0p') == '1100001110000'
encode('a0') == '1100001110000'
encode('\x01!\x18\x00') == '1100001110000'
encode('password') == '11100001100001111001111100111110111110111111100101100100'
encode('p0<|>>?%$') == '11100001100001111001111100111110111110111111100101100100'
作为解码此函数输出的策略,您需要对原始输入进行一些假设。
首先,可以合理地假设该消息仅包含32到126范围内的可打印ASCII值。在这种情况下,每个输入字符将被编码为6或7个二进制数字的块。输出,并且每个块都将以1
开头(因为format(ord(i),'b')
不会以0
开头,除非i==0
)。
例如,假设您要解码以下字符串:
11010001100101110110011011001101111
第一个块必须为7位,否则下一个块将以0
开头,这是不可能的。
1101000 1100101110110011011001101111
对于下一个块,看来我们可以消耗6位并保留一个以1
开头的字符串:
1101000 110010 1110110011011001101111
但是,如果这样做,将不可能再提取6或7位并留下以1
开头的字符串:
### invalid ###
1101000 110010 111011 0011011001101111
### invalid ###
1101000 110010 1110110 011011001101111
这表明先前的假设是错误的。使用backtracking算法,您可以识别编码数据的所有有效分区。
由于长的编码字符串可能具有大量有效的分区,因此您可能还需要根据启发式方法对每个可能的输入字符串进行排名,例如字母字符数减去非字母字符数。在上面的示例中,password
将获得8分,而p0<|>>?%$
将获得-7分。正确的输入字符串可能是得分最高的选择之一。
它无法正常工作
s =(" Hello")
#Encrypted
res = ''.join(format(ord(i),'b') for i in s)
print("Encrypted:" + res)
#Decrypt
res = ''.join([chr(int(res[i:i+7],7)])
print("Decrypted: " + res)
结果:
加密:10000010010001100101101110110011011001101111
解密:AKYY /
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。