凯撒密码和反密码

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

加密过程
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))

参考

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 0x01 目录 常见编码: ASCII编码 Base64/32/16编码 shellcode编码 Quoted-p...
    H0f_9阅读 13,001评论 2 17
  • CTF中那些脑洞大开的编码和加密 0x00 前言 正文开始之前先闲扯几句吧,玩CTF的小伙伴也许会遇到类似这样的问...
    查无此人asdasd阅读 6,098评论 0 19
  • 古典密码学之所以被称为古典,是因为区别于现代密码学,这些密码理论虽然很有价值,但是现在很少使用。因此,学习古典密码...
    SukFortune阅读 18,540评论 2 9
  • 在娱乐至死的当今,可谓群星璀璨,要当明星当网红是多少少男少女的梦想!而在旋转舞台上、在追光灯下的明星生活真的那么惬...
    郭妮芳阅读 918评论 1 2
  • 高调和低调 乐队的吹喇叭吹号, 有人吹高调, 有人爱低调,音调和谐才最好。其实我们都知道, 高调调门高, 传播的悠...
    阿超Lilian阅读 131评论 0 0