关于Linux下的crypt加密

调试pfsense开源防火墙时,需要修改初始密码。故用到此函数

#include <unistd.h>
char *crypt(const char *key, const char *salt); 




以上是关于crypt函数的说明。参数key是待加密的字符串,salt是影响加密结果的字符串。

为了查看一个用户输入的密码是否与该登录用户的密码一致,可以先获得与当前登录用户的用户名,然后查看/etc/shadow文件,从文件中提取出salt,然后调用crypt进行计算,将得到的结果与/etc/shadow中的加密密码字段比较,若一致则说明用户输入密码正确。

/etc/shadow文件中的salt就是密码字段中的第一个"$"到第三个"$"的内容。


如下是试验机中的/etc/shadow文件中一个用户的密码字段,该密码测试时用123456

$6$y9cP0qlmDYgBk6OZ$W25lC2x90QIrNde8TVJY.D2tjAiQUHF.oaPeKXZSpX93aGyN8lzyDeCOj2Dsl0g9TtTgz.tDfTOfpbyXvN0kP0

其中salt就是

$6$y9cP0qlmDYgBk6OZ$

下面是测试程序:

#include <stdio.h>  
#include <unistd.h>  
#include <stdlib.h>  
#define _XOPEN_SOURCE  
  
int main(void)  
{  
        char *passwd;  
        char key[] = "123456";  
        passwd = crypt(key, "$6$y9cP0qlmDYgBk6OZ$");  
        printf("password: %s\n", passwd);  
        return 0;  
}  

linux下gcc编译时

gcc pass.c -o pass -lcrypt


运行后输出结果为:

password: $6$y9cP0qlmDYgBk6OZ$W25lC2x90QIrNde8TVJY.D2tjAiQUHF.oaPeKXZSpX93aGyN8lzyDeCOj2Dsl0g9TtTgz.tDfTOfpbyXvN0kP0


参考资料:

http://blog.csdn.net/yjp19871013/article/details/8425356

http://baike.baidu.com/link?url=YgHD3e0s00nVgUtudjo_JsgQMbPBTWXvhSg-nEBAx91C6972qWPV69JxLQUhHtf9Pwr_KO2Vbz8cQJep-XqT_a





  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值