myshell实现Sudo三部曲 : 阴影口令

在上篇博客中,我们讲了设置用户位的作用, 有了seteuid这个函数, 我们就可以实现从普通用户权限转变为root权限. 但是我们的shell还需要密码验证模块. 要实现这个模块, 我们必须先得到用户密码.

在linux中, 有一个通常称为阴影口令(shadow password)的文件, 这个文件中包含这用户名和加密口令以及其他信息. 注意: 是加密口令, 没有哪个系统会随便到将密码明文存储.

阴影口令文件不应是一般用户可以读取的, 仅有少数几个程序需要访问加密口令, 比如login 和 passwd. 这些程序常常是设置用户ID为root的程序(上篇博客讲解了 设置用户ID).
在linux中有一组函数可以用于访问阴影口令文件 :


下面介绍几个获取信息的函数

  • struct spwd *getspnam(const char *name)

    将用户名传参进去, 返回该用户的spwd结构体指针. 若出错, 则返回NULL

  • void setspent(void)

    将读取指针指向阴影口令的起始位

  • struct spwd *getspent(void)

    顺序读取存放的这些结构体

  • void endspent(void)

    读取后关闭读取指针

后三个函数是需要组合使用的, 它的工作原理类似与文件指针读取文. 注意: 读取阴影口令, 需要root权限

下面是返回结构体的详细内容, 在Sudo这个模块中,我们只需要加密口令

说明struct spwd成员
用户登录名char *sp_namp
加密口令char *sp_pwdp
上次更改口令以来经过的时间int sp_lstchg
经多少天后允许更改int sp_min
要求更改尚余天使int sp_max
超期警告天数int sp_warn
账户不活动之前尚余天数int sp_inact
账户超期天数int sp_expire
保留unsigned int sp_flag
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值