我正在尝试编写一个可以使用分组密码加密和解密文本的 python 脚本,但我一直得到完全空白的输出。在尝试追查问题的根源后,我意识到在执行 XOR 位运算 (a^b) 后,我的脚本无法将新的 ascii 值转换为字符。
def blockcrypt(text,key):
rawkeylist = rawintkey(key)
textlist = asciitextlist(text)
answer=''
kli = 0
for element in textlist:
answer+=str(unichr(element^rawkeylist[kli]))
kli+=1
if kli==len(rawkeylist):
kli=kli%len(rawkeylist)
return answer
其中 rawkeylist 是将原始键转换为每个字符的 ascii 值(十进制)列表。而 textlist 是将文本转换为每个字符的十进制 ascii 值列表。我已经使用 print 来确认这些正在输出正确的列表。
问题是我尝试过的几个输入没有产生答案。更重要的是,通过将 print 替换到各个地方,我发现 str(unichr(element^rawkeylist[kli])) 在对 unichr 进行了一些研究后没有输出任何内容,我发现它实际上输出了 u'____' (带有 _____充当占位符)。
我不能将我的 ASCII 值转换回字符,但这似乎不是最具创新性的解决方案。我也非常怀疑使用字符串添加到我的答案的有效性。最后,我只是在应用密码时通过密钥的字符进行循环,在做了一些研究之后,我听说了一种我觉得我应该使用的叫做填充的东西。
所以嗯,请帮助我猜。