关注公众号 “融码一生”,领取全套 PDF / 电子书
/etc/shadow
文件用于存储 Linux 系统中用户的密码信息,又称“影子文件”。- 由于
/etc/passwd
文件允许所有用户读取,易导致用户密码泄露,因此 Linux 系统将用户的密码信息从/etc/passwd
文件中分离出来并单独放到此文件中。 /etc/shadow
文件只有 root 用户拥有读权限,其他用户没有任何权限,保证了用户密码的安全性。- 注意:如果这个文件的权限发生了改变,则需注意是否是恶意攻击。
- 同
/etc/passwd
文件一样,文件中每行代表一个用户,同样使用:
作为分隔符,不同之处在于,每行用户信息被划分为 9 个字段:
-
用户名:加密密码:最后一次修改时间:最小修改时间间隔:密码有效期:密码需要变更前的警告天数:密码过期后的宽限时间:账号失效时间:保留字段
- 用户名
-
- 同
/etc/passwd
文件的用户名有相同的含义。
- 同
- 加密密码
-
- 这里保存的是真正加密的密码。目前 Linux 的密码采用
SHA512
散列加密算法,原来采用MD5
或DES
加密算法。SHA512
散列加密算法的加密等级更高,也更安全。 - 注意:这串密码产生的乱码不能手工修改,如果手工修改,系统将无法识别密码,导致密码失效。很多软件通过这个功能,在密码串前加上
"!"
、"*"
或"x"
使密码暂时失效。 - 所有伪用户的密码都是
!!
或*
,代表没有密码、不能登录。新创建的用户如果不设定密码,则它的密码项也是!!
,代表这个用户没有密码、不能登录。
- 这里保存的是真正加密的密码。目前 Linux 的密码采用
- 最后一次修改时间
-
- 此字段表示最后一次修改密码的时间;为什么 root 用户显示的是 15775?
- 因为 Linux 计算日期的时间是以 1970 年 1 月 1 日作为 1 不断累加得到的时间,到 1971 年 1 月 1 日则为 366 天。这里显示 15775 天,表示此 root 账号在 1970 年 1 月 1 日之后的第 15775 天修改的 root 用户密码。
- 到底 15775 代表的是哪一天?可以使用命令进行换算:
-
-
date -d "1970-01-01 15775 days"
- 输出结果:2013年03月11日 星期一 00:00:00 CST
-
- 最小修改时间间隔
-
- 最小修改间隔时间,该字段规定了从第 3 字段(最后一次修改密码的日期)起,多长时间之内不能修改密码。如果是 0,则密码可以随时修改;如果是 10,则代表密码修改后 10 天之内不能再次修改。
- 此字段是为了针对某些人频繁更改账户密码而设计的。
- 密码有效期
-
- 经常变更密码是个好习惯,为了强制要求用户变更密码,这个字段可以指定距离第 3 字段(最后一次更改密码)多长时间内需再次变更密码,否则该账户密码进行过期阶段。
- 该字段的默认值为 99999,也就是 273 年,可认为是永久生效。如果改为 90,则表示密码被修改 90 天之后必须再次修改,否则该用户即将过期。管理服务器时,通过这个字段强制用户定期修改密码。
- 密码需要变更前的警告天数
-
- 当账户密码有效期快到时,系统会发出警告信息给此账户,提醒用户 "再过 n 天你的密码就要过期了,请尽快重新设置你的密码!"。
- 该字段的默认值是 7,即距离密码有效期的第 7 天开始,每次登录系统都会向该账户发出 "修改密码" 的警告信息。
- 密码过期后的宽限天数
-
- 也称为“口令失效日”;在密码过期后,用户如果还是没有修改密码,则在此字段规定的宽限天数内,用户还是可以登录系统的;如果过了宽限天数,系统将不再让此账户登陆,也不会提示账户过期,是完全禁用。
- 比如此字段规定的宽限天数是 10,则代表密码过期 10 天后失效;如果是 0,则代表密码过期后立即失效;如果是 -1,则代表密码永远不会失效。
- 账号失效时间
-
- 同第 3 个字段一样,使用自 1970 年 1 月 1 日以来的总天数作为账户的失效时间。该字段表示,账号在此字段规定的时间之外,不论你的密码是否过期都将无法使用!
- 该字段通常被使用在具有收费服务的系统中。
- 保留
-
- 这个字段目前没有使用,等待新功能的加入。
- 忘记密码怎么办
-
- 经常有读者会忘记自己的账户密码,该怎么处理?
- 对于普通账户的密码遗失,可以通过 root 账户解决,它会重新给你配置好指定账户的密码,而不需知道你原有的密码(利用 root 的身份使用 passwd 命令即可)。
- 如果 root 账号的密码遗失,则需要重新启动进入单用户模式,系统会提供 root 权限的 bash 接口,此时可以用 passwd 命令修改账户密码;也可以通过挂载根目录,修改
/etc/shadow
,将账户的 root 密码清空,使得 root 无密码即可登陆,登陆后使用 passwd 命令配置 root 密码。
关注公众号 “融码一生”,领取全套 PDF / 电子书