crypt() 原型如下:
[C++] 纯文本查看 复制代码 #include <unistd.h>
char *crypt(const char *key, const char *salt);
crypt() 函数主要用来加密密码,比如你在用 getpass() 函数获取用户的一个输入密码后,即可使用 crypt() 来加密,但它并不适合用来加密其它的文本数据。
crypt() 的加密基于 DES (Data Encryption Standard) 算法,该算法是对称算法。
其中,参数 key 是我们要加密的密码;而 salt 是 'a-z', 'A-Z', '0-9' 以及 '.' 和 '/' 这 64 个字符中任选其中两个,这样就有了 4096 种不同的用来初始化该算法的方法。
在 crypt() 中,不管我们输入的密码有多长,函数最终只取其前 8 个字节(共 64 位),然后对每个字节取低 7 位,总共 56 位,这 56 位组成一个键(key),算法会用这个键反复的加密一个常字符串(通常这个字符串为全 0),最后获得一个具有 13 个字符长度的加密密码,其中前面两个字符为参数 salt 。
测试代码:
[C++] 纯文本查看 复制代码 #include <stdio.h>
#include <unistd.h>
#include <string.h>
int main()
{
char *key;
char slat[2];
key = getpass("Input your password: ");
slat[0] = key[0];
slat[1] = key[1];
printf ("After crypt() :%s\n", crypt(key, slat));
return 0;
}
运行输出:./crypt
Input your password: //输入 123456789
After crypt() :12yJ.Of/NQ.Pk
也许在更新的 Linux 发行版里,你需要使用 -lcrypt 选项才能成功编译带有 crypt() 函数的程序。 |