C语言—密码加密

本文介绍了一种使用C语言实现密码输入时回显为*的方法。通过getch()函数读取字符并利用isprint()判断字符是否可打印,同时支持删除操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

输入密码回显*的函数

我们都知道,大多数情况下,在密码输入过程中,我们看不见密码本身,随之显示在屏幕上的是一系列*,今天就用C语言实现这个过程。

核心思想:使用getch()函数读取密码(getch()函数读入数据时不显示输入内容,并且不需要回车就能自动终止输入),并依次将字符存入一个数组中,当要删去字符时,\b起到了重要的作用,即 先退格,输出空格用来掩盖当前字符,再退格,就在视觉上删去了那一个*,同时让数组元素减一重新录入就好。


以下是函数的代码:
#include<stdio.h>
#include<conio.h>
#include<ctype.h>

void secretword(char key[]){
    unsigned char c;
    int i=0;
    while((c=getch())!='\r'){
        if(i<20&&isprint(c)){
            key[i]=c;
            i++;
            putchar('*');
        }
        else if(i>0&&c=='\b'){
            i--;
            putchar('\b');
            putchar(' ');
            putchar('\b');
        }
    }
    printf("\n");
    key[i]='\0';
} 

int main(){
    printf("请输入密码:");
    char key[20];
    secretword(key);
    printf("\n密码是:");
    printf("%s",key);
}
  • 其中 isprint()函数是 ctype.h 中的函数,用来判断字符是否可以被打印显示,若可以则返回非零值,若不可以则返回0.
某同学在宿舍公用计算机上面使用文本文件来记录每天的心情故事,但是宿舍公用计算机不能设置密码,同学担心自己的日记被偷看,特委托你来完成如下加密程序: 该程序是一个可加密数据的日记记录工具,具有如下功能要求: 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: 好的,下面是一个简单的 C 语言密码加密函数的例子: ``` #include <stdio.h> #include <string.h> void encrypt(char *password) { int i; for (i = 0; i < strlen(password); i++) { password[i] = password[i] + 1; // 将每个字符的 ASCII 码加 1 } } int main() { char password[] = "password"; encrypt(password); printf("加密后的密码是: %s\n", password); return 0; } ``` 该函数会将输入的密码字符串中的每个字符的 ASCII 码都加 1,从而实现密码加密的效果。 注意:这只是一个简单的例子,并不能作为真正的加密方案。如果你想要用于实际的密码加密,建议使用更加安全的加密算法,比如 AES 或 RSA。 ### 回答2: 在C语言中,可以使用一些常见的密码加密算法来编写一个密码加密函数。这里我为你提供一个简单的例子,使用了Caesar密码算法。 Caesar密码算法是一种简单的替换加密方法,将明文中的每个字母按照一个固定的规律进行替换。具体步骤如下: 1. 首先,定义一个整数变量key,用来表示替换规则。 2. 将明文逐个字符读取,并判断其是否为字母。 3. 如果是字母,则将其ASCII码值加上key;如果该字母是大写字母,还需要判断是否超出大写字母的范围。 4. 对于非字母字符,不进行替换,直接保留原样。 5. 将替换后的字符逐个输出,即为加密后的密文。 下面是一个示例的C语言代码: ```c #include <stdio.h> void encrypt(char* text, int key) { int i = 0; while (text[i] != '\0') { if (text[i] >= 'A' && text[i] <= 'Z') { // 处理大写字母 text[i] = (text[i] - 'A' + key) % 26 + 'A'; } else if (text[i] >= 'a' && text[i] <= 'z') { // 处理小写字母 text[i] = (text[i] - 'a' + key) % 26 + 'a'; } i++; } } int main() { char text[100]; int key; printf("请输入明文: "); fgets(text, sizeof(text), stdin); printf("请输入替换规则(整数): "); scanf("%d", &key); encrypt(text, key); printf("加密后的密文: %s", text); return 0; } ``` 在示例代码中,我们通过调用encrypt函数来对输入的明文进行加密。你可以根据自己的需求修改这个函数或选择其他更复杂的加密算法。请注意,这只是一个简单的示例,实际的密码加密函数需要更加复杂且安全。 ### 回答3: 当然可以帮您编写一个简单的C语言密码加密函数。下面是一个示例: ```c #include <stdio.h> #include <string.h> void encryptPassword(char* password) { int len = strlen(password); for (int i = 0; i < len; i++) { password[i] = password[i] + 3; // 将每个字符的ASCII值增加3 } } int main() { char password[20]; printf("请输入密码:"); scanf("%s", password); encryptPassword(password); // 调用加密函数 printf("加密密码为:%s\n", password); return 0; } ``` 此函数接受一个字符串作为参数,并对每个字符的ASCII值进行加密操作,具体操作是将ASCII值增加3。加密后的密码将存储在原始字符串中。 在`main()`函数中,首先通过`scanf()`函数获取要加密密码,并将其传递给`encryptPassword()`函数进行加密。然后,将加密后的密码进行输出。 请注意,此示例函数只是一个简单的示范,实际中密码加密需要更为复杂的算法,并考虑到密码安全性。这里的加密方法只是为了展示基本的C语言字符串操作。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值