0

0

Linux /etc/passwd /etc/shadow 文件解析

冰川箭仙

冰川箭仙

发布时间:2026-02-28 13:29:03

|

391人浏览过

|

来源于php中文网

原创

/etc/passwd共7字段,用:切分但需防第7字段含参数;/etc/shadow共9字段、仅root可读,第2字段为哈希,须校验格式;不一致导致登录失败或审计告警。

linux /etc/passwd /etc/shadow 文件解析

passwd 文件每行字段怎么拆解

直接用 : 切分就行,但别硬写 split(':') 就完事——第 1、2、5、6 字段可能含空格或逗号,而第 7 字段(shell 路径)可能带参数(比如 /bin/sh -c),实际系统里极少这么用,但解析脚本得防住。标准字段共 7 个,顺序固定:

  • username:登录名,不可为空,不支持 : 和空格
  • password:早期明文密码占位,现在全是 x*,真密码在 /etc/shadow
  • uid:数字,0 是 root,1–999 通常是系统用户(不同发行版范围略有差异)
  • gid:主组 ID,对应 /etc/group 中的组
  • gecos:逗号分隔的用户信息(全名、办公室、电话等),可为空,但字段本身不能省略
  • home_dir:必须是绝对路径,/root/home/alex 这类,不检查是否存在
  • shell:必须是可执行文件路径,/bin/bash/usr/sbin/nologin 算合法;空值或非法路径会导致 login 失败,但 passwd 文件本身仍算语法正确

shadow 文件权限和字段含义

/etc/shadow 默认权限是 000(即 ----------),只有 root 可读——普通用户连 ls -l 都看不到内容,更别说解析。字段共 9 个,用 : 分隔,第 2 字段(密码哈希)是核心:

  • username:必须与 /etc/passwd 中一致,否则登录时找不到匹配项
  • password_hash:以 $id$salt$hash 格式存储,id=1 是 MD5,id=6 是 SHA-512(主流),id=ya 是 yescrypt(较新)。空值(::)表示无密码;*! 表示锁定账户
  • last_pwd_change:从 1970-01-01 起的天数,不是秒数;值为 0 表示下次登录强制改密
  • min_days:两次改密最小间隔(天),0 表示不限制
  • max_days:密码有效期(天),99999 常见,等于约 273 年
  • warn_days:过期前多少天开始警告用户
  • inactive_days:过期后多少天禁用账户(设为 0 表示立即禁用)
  • expire_date:账户绝对过期时间(从 epoch 起的天数),1 表示 1970-01-02,-1 表示永不过期
  • reserved:保留字段,目前始终为空

用 Python 安全读取 shadow 的常见错误

想用 open('/etc/shadow')?非 root 用户会直接报 PermissionError: [Errno 13] Permission denied。绕过权限检查(比如用 sudo python script.py)也不推荐——脚本一旦有 bug,可能意外泄露哈希。真实场景中,应该:

爱图表
爱图表

AI驱动的智能化图表创作平台

下载
  • 只在 root 权限下运行,且明确检查 os.geteuid() == 0
  • 避免把整行 password_hash 打印或记录到日志,哪怕只是调试
  • 别用 csv.reader 解析,它默认处理引号和转义,而 shadow 没这些规则,纯 line.strip().split(':', 8) 更可靠(注意切 8 次,确保最后字段包含所有剩余内容)
  • password_hash 字段做基础校验:以 $ 开头、至少含两个 $、长度 >10,能过滤掉明显异常值(比如空字段或 * 后多出的垃圾字符)

passwd 和 shadow 字段不一致会怎样

系统不会在写入时强校验一致性,所以人工编辑或脚本出错后,问题往往延迟暴露:

  • /etc/passwd 里有用户 alice,但 /etc/shadow 没这行 → 登录时提示 Authentication failure,实际是找不到密码记录
  • /etc/shadow 里有 bob,但 /etc/passwd 没这行 → usermodpasswd 命令会报 user bob does not exist,但系统启动或 PAM 加载时通常不报错
  • uid 在 passwd 里是 1001,但 shadow 里对应行写成 1002 → 不影响登录,因为 shadow 根本不看 uid,只认 username;但后续用 getent passwd bob 查到的 uid 和 getent shadow bob 返回的字段是割裂的,审计工具可能告警

真正麻烦的是跨字段逻辑耦合:比如 home_dir 设为 /nonexistent,而 shell/bin/bash,用户能登录但立刻被踢出——这种问题不在文件格式层面报错,得靠实际测试。

相关文章

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1541

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

715

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

300

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

793

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

585

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

566

2023.07.20

linux查看ip命令
linux查看ip命令

本专题为大家提供linux查看ip命令相关文章内容,感兴趣的朋友可以免费下载体验试试。

309

2023.07.20

linux查看cpu使用率
linux查看cpu使用率

在linux的系统维护中,可能需要经常查看cpu使用率,分析系统整体的运行情况。本专题为大家带来了linux查看cpu使用率的相关文章,感兴趣的朋友千万不要错过了。

397

2023.07.25

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

0

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.8万人学习

Git 教程
Git 教程

共21课时 | 3.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号