换位密码

    在计算机出现之前,密码学由基于字符的密码算法构成。不同的密码算法是字符之间的互相替代或是互相之间的换位。好的密码是结合这两种方法,每次进行多次运算。这些算法的安全性是基于算法的保密性,一旦算法被泄露,就很容易被破译,在今天看来它们都是一些比较简单的密码,虽然现在加密更复杂,但原理没变,只是算法对位而不是对字母进行变换。了解过去的密码仍然是一件很有意义的事。

换位密码就是一种早期的加密方法,明文的字母保持相同,但顺序被打乱了。在简单的纵行换位密码中,明文以固定的宽度水平的写在一张图表纸上,密文按垂直方向读出,解密就是密文按相同的宽度垂直的写在图表纸上,然后水平的读出明文。例如周期为e的换位是将明文字母划分为组,每组e个字母,密钥是12…e的一个置换f。然后按照公式Yi+ne=Xf(i)+ ne,(其中i=1…en=01)将明文X1X2X3…加密为密文Y1Y2Y3…。解密过程则按照下式进行:Xj+ne=Yf-1j+ ne,(其中j=1…en=01…)。

明文:COMPUTER CRAPHICS MAY BE SLOW BUT ATLEASTTIE’S EXPENSIVE

   C   O   M   P   U   T   E   R   G   R

   A   P   H    I   C   S   M   A   Y   B

   E   S   L    O   W  B   U   T    A   T

   L   E   A    S   T   I    T   S    E   X

   P   E   N    S   I   V    E

密文:CAELP OPSEE MHLAN PLOSS UCWTI TSBIV EMUTE RATSG YAERB TX

 由于密文字符和明文字符相同,对密文的频数分析将揭示和英语有相似的或然值。这给了密码分析者很好的线索,他能用各种技术去决定字母的准确顺序,以得到明文。密文通过两次换位密码极大增强了安全性。

   虽然现代密码也用换位,但由于它对存储要求很大,有时还要求消息为某个特定的长度,因此比较麻烦。代替密码要常用的多。  

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Python可以使用以下方式实现凯撒密码和栅栏密码: 凯撒密码一种简单的密码换方法,通过对原文每个字母进行移位来加密解密。在Python,可以使用ord()和chr()函数来实现字母的ASCII码和字符之间的换。 例如,我们要将明文字符串"HELLO"使用凯撒密码进行加密,假设移位值为3: ```python def caesar_cipher_encrypt(plaintext, shift): ciphertext = "" for char in plaintext: if char.isalpha(): # 只对字母进行加密 ascii_value = ord(char.upper()) # 换为大写字母的ASCII码 shifted_ascii_value = (ascii_value - 65 + shift) % 26 + 65 # 字母移位 ciphertext += chr(shifted_ascii_value) # 换为加密后的字符 else: ciphertext += char # 非字母字符直接添加到密文 return ciphertext plaintext = "HELLO" shift = 3 ciphertext = caesar_cipher_encrypt(plaintext, shift) print(ciphertext) # 输出:KHOOR ``` 栅栏密码一种换位密码,通过将明文的字母按照一定的规则重新排列来加密解密。在Python,可以使用循环和切片操作来实现栅栏密码。 例如,我们要将明文字符串"HELLO"使用栅栏密码进行加密,假设栏数为2: ```python def rail_fence_cipher_encrypt(plaintext, num_rails): rails = [[] for _ in range(num_rails)] # 创建栅栏列表 current_rail = 0 direction = 1 # 标识方向 for char in plaintext: rails[current_rail].append(char) # 根据当前栏添加字符 if current_rail == num_rails - 1: # 到达最后一栏时改变方向 direction = -1 elif current_rail == 0: # 回到第一栏时改变方向 direction = 1 current_rail += direction # 改变当前栏 ciphertext = "" for rail in rails: ciphertext += "".join(rail) # 将栏内字符拼接成密文 return ciphertext plaintext = "HELLO" num_rails = 2 ciphertext = rail_fence_cipher_encrypt(plaintext, num_rails) print(ciphertext) # 输出:HLOEL ``` 以上就是使用Python实现凯撒密码和栅栏密码的简单示例,这些代码可以作为基础来进一步扩展和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值