900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > python123凯撒密码_凯撒密码和反密码

python123凯撒密码_凯撒密码和反密码

时间:2020-07-17 02:57:37

相关推荐

python123凯撒密码_凯撒密码和反密码

在密码学中,恺撒密码是一种最简单且最广为人知的加密技术。它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。

加密过程

1.从1到25决定一个数字为密钥。保持这个密钥的秘密!

2.找到明文字母的号码。

3.添加密钥数字到明文字母的号码,生成一个数字。

4.如果这个数字大于26,减去26。

5.找到你计算的数字对应的字母。这就是密文。

6.对明文中的每个字母重复步骤2

下图描述了如何使用密钥13加密“Hello. How are you?”。每个行都显示了将左边的明文字母转到右侧的密文的步骤。

加密

解密,减去密钥数字,而不是添加它。对于密文B,数字是1。减去1 - 13得到- 12。像我们的“减法26”加密规则,当我们解密和结果是小于0,我们有一个“添加26”规则。- 12 + 26是14。所以密文字母B解密回字母O。

解密

双强度加密

如果我们对“KITTEN”3键,得到的密文就是“nlwwhq”。如果我们对“nlwwhq”4键,得到的密文,将“rpaalu”。但这与我们用“7”键一次加密“小猫”一词是完全一样的。我们的“双”加密和普通加密是一样的,所以它没有更强的。

对于大多数加密算法,加密一次以上不提供额外的密码强度。事实上,如果你用两个加起来等于26的密钥加密一些明文,你最终得到的密文和原来的明文是一样的!

代码实现

import string

# 凯撒加密

def encrypt(your_str, key):

C = string.ascii_letters

# 生成符号映射

lc = [chr((i - 97) % 26 + 97) for i in range(97 + key, 123 + key)]

uc = [chr((i - 65) % 26 + 65) for i in range(65 + key, 91 + key)]

R = ''.join(lc) + ''.join(uc)

# python3.2之前的maketrans使用string调用,从3.2之后发生改变

return your_str.translate(str.maketrans(C, R))

# 凯撒解密

def decrypt(your_str, key):

C = string.ascii_letters

# 生成符号映射

lc = [chr((i - 97) % 26 + 97) for i in range(97 + key, 123 + key)]

uc = [chr((i - 65) % 26 + 65) for i in range(65 + key, 91 + key)]

R = ''.join(lc) + ''.join(uc)

return your_str.translate(str.maketrans(R, C))

if __name__ == '__main__':

plainText = 'hello world!'

cipherText = encrypt(plainText, 7)

print(cipherText)

plainText = decrypt(cipherText, 7)

print(plainText)

反密码

反向密码通过反向打印来加密消息。所以“Hello world!” 加密到“!dlrow olleH”。要解密,只需反转反向消息即可得到原始消息。加密和解密步骤相同。这是一种非常脆弱的密码。只要看它的密文,你可以发现它只是相反的顺序。 .syas ti tahw tuo erugif llits ylbaborp nac uoy ,detpyrcne si siht hguoht neve ,elpmaxe roF。

# Reverse Cipher

message = 'Three can keep a secret, if two of them are dead.'

translated = ''

i = len(message) - 1

while i >= 0:

print(translated)

translated = translated + message[i]

i = i - 1

这样写其实很不符合Python优雅的特性,对代码进行大改造:

# Reverse Cipher

message = 'Three can keep a secret, if two of them are dead.'

def reverseDecrypt(str):

return ''.join(reversed(message))

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。