1

我正在尝试编写一个可以使用分组密码加密和解密文本的 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 值转换回字符,但这似乎不是最具创新性的解决方案。我也非常怀疑使用字符串添加到我的答案的有效性。最后,我只是在应用密码时通过密钥的字符进行循环,在做了一些研究之后,我听说了一种我觉得我应该使用的叫做填充的东西。

所以嗯,请帮助我猜。

4

1 回答 1

0

您可以继续将密文视为字节(例如,您可以存储二进制文件或通过 HTTP 发送二进制数据),也可以使用 base 64 或十六进制编码将其编码为文本。在解密之前,您当然应该将字符串解码回二进制密文。

于 2014-12-28T21:10:04.733 回答