胖蔡说技术
随便扯扯

Python 实现凯撒加解密

凯撒加密法指的是两千年前由凯撒大帝使用的加密法,是一种最简单且最广为人知的加密技术。它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。历史上,通常使用一个加密轮盘将明文加密成密文。

加密轮盘

介绍

凯撒加密法属于一种常见的堆成加密方式,也是一种其他更加复杂加密算法的一个加密步骤。其加解密如下:

实现

如下,提供Python实现凯撒加密实现的源码:

#caesarCipher.py
import pyperclip

message = "this is secret message"

key =  13  # 加解密key

mode = "encrypt"  # 模式,支持encrypt(加密)、decrypt(解密)

LETTERS = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"

translated = ""
message = message.upper()

for symbol in message:
    if symbol in LETTERS:
        num = LETTERS.find(symbol)
        if mode = "encrypt":
            num = num + key
        elif mode == "decrypt":
            num = num - key

        if num >= len(LETTERS):
            num = num - len(LETTERS);
        elif num < 0:
            num = num + len(LETTERS);
    else:
        translated =  translated + symbol

print(translated)   #输出加密或解密结果

这里提供了一个实现,若是需要将其作为一个工具使用,还需要将其封装成单独的一个模块,通过在main函数中传入的值进行判断运行实现加密或解密的功能。

赞(0) 打赏
转载请附上原文出处链接:胖蔡说技术 » Python 实现凯撒加解密
分享到: 更多 (0)

请小编喝杯咖啡~

支付宝扫一扫打赏

微信扫一扫打赏