C语言实现加密解密功能 附带详细注释源码

13 篇文章 2 订阅

加密主要是通过一种算法对原内容进行处理,使原来内容不直观可见。解密过程通常要知道加密的算法,然后对加密后的内容进行逆处理,从而实现解密功能。当然解密也有一些暴力破解的方法。接下来以 c 语言 为例讲解一种简单的加密解密以及暴力破解字符串的方法,带您走进加密解密技术的大门。

先讲一下凯撒加密,凯撒密码相传是古罗马凯撒大帝用来保护重要军情的加密系统。它是一种置换密码,通过将字母顺序推后起到加密作用。如字母顺序推后 3 位,字母 A 将被推作字母 D,字母 B 将被推作字母 E。本实例类似于凯撒加密。

加密算法:

大(小)写字母加密后还为大(小)写字母。大(小)写字母向后推 n 位,n 由用户输入,如果超出大(小)写字母的 ASCII 范围,则返回至第一个大(小)写字母继续循环。

解密算法(与加密算法正好相反):

大(小)写字母解密后还为大(小)写字母。大(小)写字母向前推 n 位,n 由用户输入,如果超出大(小)写字母的 ASCII 范围,则返回至最后一个大(小)写字母继续循环。

代码如下:

/*字符串加密解密程序 凯撒加密*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

//函数encode()将字母顺序推后n位,实现文件加密功能
void encode(char str[],int n){
    char c;
    int i;
    for(i=0;i<strlen(str);++i){  //遍历字符串
        c=str[i];
        if(c>='a' && c<='z'){  //c是小写字母
            if(c+n%26<='z'){  //若加密后不超出小写字母范围
                str[i]=(char)(c+n%26);  //加密函数
            }else{  //加密后超出小写字母范围,从头开始循环小写字母
                str[i]=(char)(c+n%26-26);
            }
        }else if(c>='A' && c<='Z'){ //c为大写字母
            if(c + n%26 <= 'Z'){  //加密后不超出大写字母范围
                str[i]=(char)(c+n%26);
            }else{  //加密后超出大写字母范围,从头开始循环大写字母
                str[i]=(char)(c+n%26-26);
            }
        }else{  //不是字母,不加密
            str[i]=c;
        }
    }
    printf("\nAfter encode: \n");
    puts(str);  //输出加密后的字符串
}


//decode()实现解密功能,将字母顺序前移n位
void decode(char str[],int n){
    char c;
    int i;
    //遍历字符串
    for(i=0;i<strlen(str);++i){
        c=str[i];
        //c为小写字母
        if(c>='a' && c<='z'){
            //解密后还为小写字母,直接解密
            if(c-n%26>='a'){
                str[i]=(char)(c-n%26);
            }else{
                //解密后不为小写字母了,通过循环小写字母处理为小写字母
                str[i]=(char)(c-n%26+26);
            }
        }else if(c >= 'A' && c<='Z'){  //c为大写字母
            if(c-n%26>='A'){  //解密后还为大写字母
                str[i]=(char)(c-n%26);
            }else{  //解密后不为大写字母了,循环大写字母,处理为大写字母
                str[i]=(char)(c-n%26+26);
            }
        }else{  //非字母不处理
            str[i]=c;
        }
    }
    printf("\nAfter decode: \n");
    puts(str);  //输出解密后的字符串
}//该函数代码有冗余,读者可改进

int main()
{
    char str[50];
    int k=0,n=0,i=1;
    printf("\nPlease input strings: ");
    scanf("%s",str);  //输入加密解密字符串
    //打印菜单
    printf("-----------------\n");
    printf("1: Encryption\n");
    printf("2: Decryption\n");
    printf("3: Violent Crack\n");  //暴力破解
    printf("-----------------\n");
    printf("\nPlease choose: ");
    scanf("%d",&k);
    if(k==1){  //加密
        printf("\nPlease input number: ");
        scanf("%d",&n);
        encode(str,n);
    }else if(k==2){  //解密
        printf("\nPlease input number: ");
        scanf("%d",&n);
        decode(str,n);
    }else{
        for(i=1;i<=25;++i){  //尝试所有可能的n值进行暴力破解
            printf("%d ",i);
            decode(str,i);
        }
    }
    return 0;
}

测试运行如下:

成功实现加密解密功能,读者可以稍加改造完成对文件的加密解密


------再苦再难,也要坚持------

  • 18
    点赞
  • 90
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
某同学在宿舍公用计算机上面使用文本文件来记录每天的心情故事,但是宿舍公用计算机不能设置密码,同学担心自己的日记被偷看,特委托你来完成如下加密程序: 该程序是一个可加密数据的日记记录工具,具有如下功能要求: 1. 运行系统后,系统给出三个选项:1)新增日记;2)阅读日记;3)退出系统 2. 选择功能1)后,系统提示用户输入日记文件名称和路径,并创建文本文件;同时,用户输入两个字符a和b,作为密钥;创建文件后,用户开始输入日记内容,日记内容为文本形式,将日记内容加密,然后将加密后的内容写入文件中; 3. 选择功能2)后,系统提示用户输入要打开的日记文件的路径和名称,打开文件后,读取文件中的密文,解密后显示出来; 4. 加密算法推荐大家采用简单的文本加密算法实现算法思想如下,从明文读入一个字符(英文),使用密钥a与该字符做异或操作,将结果作为密文保存下来,再读入第二个字符,使用密钥b与该字符做异或操作,同样保存结果,以此类推加密全文;解密过程可将密文作为输入完成整个加密过程,返回就是明文。如果同学们有兴趣加密中文,那么可将中文的高八位使用密钥a加密,低八位使用密钥b加密,完成加密过程。 这个加密算法需要使用C语言的位运算运算符,包括:& 按位与、| 按位或、^ 按位异或、~ 取反、<> 右移。 那么本算法中的异或可用如下方法完成,c为明文中取得的一个字符,该字符加密解密)指令如下: c = plaintext[i]; //i+1是奇数使用密钥a,是偶数采用密钥b cipher[i] = c ^ a; 那么在cipher[i]中保存的就是c的密文。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值