曲径通幽论坛

标题: crypt() -- 加密函数 [打印本页]

作者: beyes    时间: 2011-12-27 19:26
标题: crypt() -- 加密函数
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() 函数的程序。




欢迎光临 曲径通幽论坛 (http://www.groad.net/bbs/) Powered by Discuz! X3.2