转置密码
转置密码是一种密码算法,其中明文中的字母顺序被重新排列以形成密文。在此过程中,不包括实际的纯文本字母。
例子
换位密码的一个简单示例是柱状换位密码,其中纯文本中的每个字符都以指定的字母宽度水平书写。密码是垂直书写的,这会产生完全不同的密码文本。
考虑纯文本hello world,让我们应用简单的列转置技术,如下所示
纯文本字符水平放置,密文以垂直格式创建:holewdlo lr。现在,接收者必须使用同一个表将密文解密为纯文本。
代码
以下程序代码演示了柱状转置技术的基本实现 -
def split_len(seq, length): return [seq[i:i + length] for i in range(0, len(seq), length)] def encode(key, plaintext): order = { int(val): num for num, val in enumerate(key) } ciphertext = '' for index in sorted(order.keys()): for part in split_len(plaintext, len(key)): try:ciphertext += part[order[index]] except IndexError: continue return ciphertext print(encode('3214', 'HELLO'))
解释
使用函数split_len(),我们可以分割纯文本字符,可以将其放置为列式或行式格式。
编码方法有助于创建带有指定列数的密钥的密文,并通过读取每列中的字符来打印密文。
输出
柱状转置技术基本实现的程序代码给出以下输出 -
注意- 密码分析者观察到执行换位技术时密码安全性显着提高。他们还指出,使用相同的转置密码重新加密密文可以提高安全性。