Python实现凯撒密码加解密以及暴力破解凯撒加密的多种可能

48 篇文章 1 订阅
20 篇文章 0 订阅


凯撒加密(Caesar Cipher),也被称为移位密码,是一种最简单的替换加密技术。它的加密过程是将明文中的每个字母在字母表中向后(或向前)移动固定数目的位置。例如,当移动数目为3时,A会被替换为D,B会被替换为E,依此类推。

凯撒密码加解密

以下是一个使用Python实现的凯撒加密的示例代码,该代码支持加密和解密功能,并可以处理大写字母、小写字母以及非字母字符(非字母字符在加密过程中保持不变):

def caesar_cipher(text, shift, direction):
    """
    凯撒加密和解密函数
    :param text: 要加密或解密的文本
    :param shift: 移位数目
    :param direction: 加密为'encrypt',解密为'decrypt'
    :return: 加密或解密后的文本
    """
    result = ""

    # 加密或解密
    if direction == 'encrypt':
        shift %= 26  # 确保shift在0到25之间
    elif direction == 'decrypt':
        shift = -shift % 26  # 解密时取反方向,并确保shift在-25到0之间
    else:
        raise ValueError("direction must be 'encrypt' or 'decrypt'")

    for char in text:
        # 处理大写字母
        if char.isupper():
            result += chr((ord(char) + shift - 65) % 26 + 65)
            # 处理小写字母
        elif char.islower():
            result += chr((ord(char) + shift - 97) % 26 + 97)
            # 非字母字符保持不变
        else:
            result += char

    return result


# 示例
text = "public key cryptosystems"
shift = 7
print("明文:", text)

encrypted_text = caesar_cipher(text, shift, 'encrypt')
print("密文:", encrypted_text)

decrypted_text = caesar_cipher(encrypted_text, shift, 'decrypt')
print("解密后的密文:", decrypted_text)

这段代码首先定义了一个caesar_cipher函数,它接受三个参数:要处理的文本text、移位数目shift以及操作方向direction(加密或解密)。函数内部,首先根据操作方向调整shift的值,确保加密时shift为正数,解密时shift为负数(通过取模操作确保结果在合理范围内)。然后,遍历文本中的每个字符,根据字符的类型(大写字母、小写字母或非字母字符)进行相应的处理。对于字母字符,通过ASCII码进行移位操作,并处理边界情况(即字母表首尾相连的情况)。最后,将处理后的字符拼接成结果字符串并返回。

暴力破解凯撒密码

在凯撒加密中,由于加密和解密过程非常简单,只是将字母在字母表中移动固定数目的位置,因此可以通过“暴力破解”的方式尝试所有可能的移位数来解密加密后的文本。这种方法虽然简单,但在移位数较少时(如常见的1-25)是有效的。

以下是一个使用Python实现的暴力破解凯撒加密的示例代码:

def brute_force_caesar(encrypted_text):
    """  
    使用暴力破解凯撒加密  
    :param encrypted_text: 加密后的文本  
    :return: 可能的解密文本和对应的移位数  
    """
    possible_decryptions = []
    # 尝试所有可能的移位数(0-25)  
    for shift in range(26):
        decrypted_text = ""
        for char in encrypted_text:
            # 处理大写字母  
            if char.isupper():
                decrypted_text += chr((ord(char) - shift - 65) % 26 + 65)
                # 处理小写字母
            elif char.islower():
                decrypted_text += chr((ord(char) - shift - 97) % 26 + 97)
                # 非字母字符保持不变
            else:
                decrypted_text += char
        possible_decryptions.append((decrypted_text, shift))
    return possible_decryptions

# 示例
encrypted_text = "wbispj rlf jyfwavzfzaltz"  # 假设这是加密后的文本,原始文本为"Hello, World!",移位数为3
possible_decryptions = brute_force_caesar(encrypted_text)
for decrypted_text, shift  in possible_decryptions:
    print(f"解密后的密文: '{decrypted_text}' 加密的位数: {shift}")

# 注意:由于我们不知道实际的移位数,暴力破解会尝试所有可能性,

然而,请注意,上面的代码实际上并没有实现“智能”的暴力破解,它只是简单地尝试了所有可能的移位数,并将每个可能的解密结果都返回了。在真实场景中,你可能需要实现一些额外的逻辑来评估哪个解密结果是“正确”的,比如通过检查解密文本中是否包含有效的单词、句子或特定的模式。

此外,如果加密文本较长且包含非字母字符,这些非字母字符在解密过程中会保持不变,因此它们可能不会提供太多关于正确移位数的线索。在这种情况下,你可能需要依赖于文本中的字母部分来尝试找到正确的解密。

凯撒密码加解密程序(C语言) 2009年09月30日 星期三 13:21 1、程序结构化,用函数分别实现 2、对文件的加密,解密输出到文件 #include #include void menu()/*菜单,1.加密 2.解密 3.退出*/ { clrscr(); printf("\n==============================================================================="); printf("\n1.Encrypt the file"); printf("\n2.Decrypt the file"); printf("\n3.Quit\n"); printf("===============================================================================\n"); printf("Please select a item:"); return; } char encrypt(char ch,int n)/*加密函数,把字符向右循环移位n*/ { while(ch>='A'&&ch='a'&&ch<='z') { return ('a'+(ch-'a'+n)%26); } return ch; } main() { int i,n; char ch0,ch1; FILE *in,*out; char infile[10],outfile[10]; textbackground(RED); textcolor(LIGHTGREEN); clrscr(); menu(); ch0=getch(); while(ch0!='3') { if(ch0=='1') { clrscr(); printf("\nPlease input the infile:"); scanf("%s",infile);/*输入需要加密的文件名*/ if((in=fopen(infile,"r"))==NULL) { printf("Can not open the infile!\n"); printf("Press any key to exit!\n"); getch(); exit(0); } printf("Please input the key:"); scanf("%d",&n);/*输入加密密码*/ printf("Please input the outfile:"); scanf("%s",outfile);/*输入加密后文件的文件名*/ if((out=fopen(outfile,"w"))==NULL) { printf("Can not open the outfile!\n"); printf("Press any key to exit!\n"); fclose(in); getch(); exit(0); } while(!feof(in))/*加密*/ { fputc(encrypt(fgetc(in),n),out); } printf("\nEncrypt is over!\n"); fclose(in); fclose(out); sleep(1); } if(ch0=='2') { clrscr(); printf("\nPlease input the infile:"); scanf("%s",infile);/*输入需要解密的文件名*/ if((in=fopen(infile,"r"))==NULL) { printf("Can not open the infile!\n"); printf("Press any key to exit!\n"); getch(); exit(0); } printf("Please input the key:"); scanf("%d",&n);/*输入解密密码(可以为加密时候的密码)*/ n=26-n; printf("Please input the outfile:"); scanf("%s",outfile);/*输入解密后文件的文件名*/ if((out=fopen(outfile,"w"))==NULL) { printf("Can not open the outfile!\n"); printf("Press any key to exit!\n"); fclose(in); getch(); exit(0); } while(!feof(in)) { fputc(encrypt(fgetc(in),n),out); } printf("\nDecrypt is over!\n"); fclose(in); fclose(out); sleep(1); } clrscr(); printf("\nGood Bye!\n"); sleep(3); getch(); } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值