c语言实现对密码(字符串)进行加密,并解密

/**习惯把密码明文存在本地文件中,这个小程序可以把存的密码以密文形式保存**/
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <time.h>
int chartoasc(char c);
int xor(int i);
char asctochar(int a);
int rand_num();
int encrypt(const char *org_pass,char *new_pass);
int decrypt(const char *new_pass,char *org_pass);

int main(int argc,char *argv[])
{
    if(argc!=2)
    {
        printf("参数输入有误!\n");
        printf("usage:<pass flag >\nflag=1:加密;flag=2:解密\n");
        return -1;
    }
    int flag = 0;
    int len = 0;
    int i = 0;
    int ret = 0;
    char password[20];
    char new_pass[50];
    char org_pass[50];
    int test1 = 0;
    int test2 = 0;
    char test3 = 0;
    char *p = NULL;

    bzero(password,sizeof(password));
    bzero(new_pass,sizeof(new_pass));
    bzero(org_pass,sizeof(org_pass));

    flag = atoi(argv[1]);
    if(flag == 1)
    {
        printf("请输入需要加密的密码:");
        scanf("%s",password);
        ret = encrypt(password,&new_pass);
        if(ret)
        {
            printf("密码加密失败!\n");
            return -1;
        }
        printf("新密码[%s]\n",new_pass);
    }
    else if(flag ==2)
    {
        printf("请输入需要解密的密码:");
        scanf("%s",password);
        ret = decrypt(password,&org_pass);
        if(ret)
        {
            printf("获取原密码失败!\n");
            return -1;
        }
        printf("原密码[%s]\n",org_pass);
    }
    else
    {
        printf("加密标志输入如有误!\n");
        return -1;
    }

    return 0;
}

/**将字符转换为ASCII值**/
int chartoasc(char c)
{
    int i= 0;
    i = c;
    return i;
}

/**将ASCII进行异或运算,产生新的ASCII值**/
int xor(int i)
{
    int m = 27;
    int result = 0;
    if(59==i || 100==i)
    {
        return i;
    }
    result = i^m;
    return result;
}

/**将ASCII值转换为字符**/
char asctochar(int a)
{
    char c;
    c = a;
    return c;
}

/**输入原密码产生新的密码**/
int encrypt(const char *org_pass,char *new_pass)
{
    char org_password[50];
    char new_password[50];
    int len = 0;
    int i = 0;
    int asc = 0 ;
    char ch = 0;
    int x = 0;

    bzero(org_password,sizeof(org_password));
    bzero(new_password,sizeof(new_password));
    strcpy(org_password, org_pass);
    len = strlen(org_password);
    for(i=0 ; i<len ; i++)
    {
        ch = org_password[i];
        asc = chartoasc(ch);
        x = xor(asc);
        new_password[i] = asctochar(x);
    }
    strcpy(new_pass,new_password);

    return 0;
}

/**输入加密后的密码返回原密码**/
int decrypt(const char *new_pass,char *org_pass)
{
    char new_password[50];
    char org_password[50];
    char ch;
    int a = -1;
    int len =0;
    int i=0;
    int x = -1;

    bzero(new_password,sizeof(new_password));
    bzero(org_password,sizeof(org_password));

    strcpy(new_password,new_pass);
    len = strlen(new_password);
    for(i=0;i<len;i++)
    {
        ch = new_password[i];
        a = chartoasc(ch);
        x = xor(a);
        org_password[i]=asctochar(x);
    }
    strcpy(org_pass,org_password);

    return 0;
}

  • 6
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
某同学在宿舍公用计算机上面使用文本文件来记录每天的心情故事,但是宿舍公用计算机不能设置密码,同学担心自己的日记被偷看,特委托你来完成如下加密程序: 该程序是一个加密数据的日记记录工具,具有如下功能要求: 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的密文。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值