首页 > 系统相关 >linux中/etc/passwd文件与/etc/shadow文件解析

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

时间:2023-05-21 21:01:48浏览次数:36  
标签:文件 Shell 登录 passwd 用户 etc


 在linux操作系统中, /etc/passwd文件中的每个用户都有一个对应的记录行,记录着这个用户的一下基本属性。该文件对所有用户可读。

  而/etc/shadow文件正如他的名字一样,他是passwd文件的一个影子,/etc/shadow文件中的记录行与/etc/passwd中的一一对应,它由pwconv命令根据/etc/passwd中的数据自动产生。但是/etc/shadow文件只有系统管理员才能够进行修改和查看。

1. /etc/passwd文件

  

  1.1 /etc/passwd文件内容格式

    用户名: 密码 : uid  : gid :用户描述:主目录:登陆shell

    举个例子:

    

#cat /etc/passwd   //利用cat命令打开查看passwd内容
root:x: 0 : 0 :Superuser:/:
daemon:x: 1 : 1 :Systemdaemons:/etc:
bin:x: 2 : 2 :Ownerofsystemcommands:/bin:
sys:x: 3 : 3 :Ownerofsystemfiles:/usr/sys:
adm:x: 4 : 4 :Systemaccounting:/usr/adm:
uucp:x: 5 : 5 :UUCPadministrator:/usr/lib/uucp:
auth:x: 7 : 21 :Authenticationadministrator:/tcb/files/auth:
cron:x: 9 : 16 :Crondaemon:/usr/spool/cron:
listen:x: 37 : 4 :Networkdaemon:/usr/net/nls:
lp:x: 71 : 18 :Printeradministrator:/usr/spool/lp:
sam:x: 200 : 50 :Samsan:/usr/sam:/bin/sh
————————————————


用户名:每个用户的标识字符串

密码:这里的x表示是暗文显示。如果是其他什么数字,就代表是密码明文。

uid:每个用户必须被分配一个userid,”0”为root保留ID.1-99为系统保留,分配给系统预定义帐号。Linux用户可以分为3类:超级用户(root  用户标识号是0)、管理用户和普通用户。


系统中有一类用户称为伪用户(psuedo users),这些用户在/etc/passwd文件中也占有一条记录,但是不能登录,因为它们的登录Shell为空。 它们的存在主要是方便系统管理,满足相应的系统进程对文件属主的要求。


  /etc/passwd文件中常见的伪用户


伪  用  户

含     义

bin

拥有可执行的用户命令文件

sys

拥有系统文件

adm

拥有帐户文件

uucp

UUCP使用

lp

lp或lpd子系统使用

nobody

NFS使用


  除了上面列出的伪用户外,还有许多标准的伪用户,例如:audit, cron, mail, usenet等,它们也都各自为相关的进程和文件所需要。


 


gid :字段记录的是用户所属的用户组。它对应着/etc/group文件中的一条记录。


  

用户描述:字段记录着用户的一些个人情况,例如用户的真实姓名、电话、地址等,这个字段并没有什么实际的用途。

主目录:用户的起始工作目录,它是用户在登录到系统之后所处的目录。在大多数系统中,各用户的主目录都被组织在同一个特定的目录下,而用户主目录的名称就是该用户的登录名。各用户对自己的主目录有读、写、执行(搜索)权限,其他用户对此目录的访问权限则根据具体情况设置。

登陆shell:用户登录后,要启动一个进程,负责将用户的操作传给内核,这个进程是用户登录到系统后运行的命令解释器或某个特定的程序,即Shell。Shell是用户与Linux系统之间的接口。Linux的Shell有许多种,每种都有不同的特点。常用的有sh(BourneShell),csh(CShell),ksh(KornShell),tcsh(TENEX/TOPS-20typeCShell),bash(BourneAgainShell)等。系统管理员可以根据系统情况和用户习惯为用户指定某个Shell。如果不指定Shell,那么系统使用sh为默认的登录Shell,即这个字段的值为/bin/sh。

若此处shell为:/sbin/nologin,则代表这个用户不能登录。这样做的好处是,ftp用户只能通过ftp登录ftp服务器,而不能登录到shell中。

2. /etc/shadow 文件内容格式

文件中的记录行与/etc/passwd中的一一对应,它由 pwconv 命令根据/etc/passwd中的数据自动产生。它的文件格式与/etc/passwd类似,由若干个字段组成,字段之间用“:”隔开,文件的每行是8个冒号分割的9个域,格式如下: 

username: passwd: lastchg: min: max: warn: inactive: expire: flag 

:加密口令:最后一次修改时间:最小时间间隔:最大时间间隔:警告时间:不活动时间:失效时间:标志

 

1 )“登录名”是与/etc/passwd文件中的登录名相一致的用户账号
2 )“口令”字段存放的是加密后的用户口令字,长度为 13 个字符。如果为空,则对应用户没有口令,登录时不需要口令;如果含有不属于集合{./ 0 -9A-Za-z}中的字符,则对应的用户不能登录。
3 )“最后一次修改时间”表示的是从某个时刻起,到用户最后一次修改口令时的天数。时间起点对不同的系统可能不一样。例如在SCOLinux中,这个时间起点是 1970 年 1 月 1 日。
4 )“最小时间间隔”指的是两次修改口令之间所需的最小天数。
5 )“最大时间间隔”指的是口令保持有效的最大天数。
6 )“警告时间”字段表示的是从系统开始警告用户到用户密码正式失效之间的天数。
7 )“不活动时间”表示的是用户没有登录活动但账号仍能保持有效的最大天数。
8 )“失效时间”字段给出的是一个绝对的天数,如果使用了这个字段,那么就给出相应账号的生存期。期满后,该账号就不再是一个合法的账号,也就不能再用来登录了。

标签:文件,Shell,登录,passwd,用户,etc
From: https://blog.51cto.com/u_15955675/6320213

相关文章

  • 关于ESXI下目录文件如何改名的教程
    第一步,ESXi控制台开启SSH 第二步,使用Powershell,SSH远程连接上ESXi服务器,命令参考:ESXi服务器地址为192.168.1.100,root用户名为root,powershell下命令为:[email protected] 第三步,参考教程中第6,7步切换到目标目录,执行重命名操作 此处给出的例子是重命名VMDK文件,对于其......
  • leetcode724
    使用数学方法:假设左边的所有数加起来的和是sum,total为数组所有元素加起来的和,当i满足中心下标的条件时,即:sum=total-sum-nums[i];2*sum+nums[i]=total;当中心下标是首位时,即左边sum为0;当中心下标是尾位时,右边total-sum-nums[i]为0;for(inti=0;i<n;++i){if(2*sum+nums[i]==......
  • Linux 文件描述符
    最近在复习tcp/ip知识,其中有关的一个问题"一台服务器做多支持多少个TCP链接"和Linux下的文件描述符有关,学习一下。Linux中,一切设备都是文件,对文件的操作都是通过文件描述符来进行的。文件描述符的定义:文件描述符在形式上是一个非负整数。实际上,它是一个索引值,指向内核为每一......
  • Android数据储存之File文件储存数据
     一.存储在内部还是外部?AndroidManifest.xml中manifest标签下有一个属性android:installLocation,用于指定应用程序安装在什么地方,该属性有三个可选值:auto:程序可能被安装在外部存储器上,例如SD卡;但是默认会被安装到手机内存中。当手机内存为空时,程序将被安装到外部存储器上;当程序安......
  • 文件上传下载
    文件上传/***文件上传*@return*/@PostMapping(value="/upload")publicStringfileUpload(@RequestParamMultipartFilefile)throwsIOException{//获取源文件名StringoriginalFilename=file.getOriginalFilename();//获取文件类型Strin......
  • 13-1 udp和internet层协议 13-2IP地址组成和分类13-4 网卡配置文件和命令 13-5 网络理
    一、查看当前机器广播的地址和mac[root@centos8~]#arp-n查看当前机器的广播地址[root@centos8~]#tcpdump-ieth0arp-nn抓包[root@centos8~]#ipaa10.0.0.100/24deveth0添加多网卡命令[root@centos8~]#arping10.0.0.100查看IP有没有被占用二、查看相关包有......
  • Linux目录下明明有可执行文件却提示找不到,“No such file or directory”
    明明一切正常,findls均可找到,权限也是777 检查文件的头部:readelf-hrepeat发现machine条目:Machine:    Intel80386问题出在了文件是32位的,但是虚拟机是64位的 如果想要运行文件,需要安装32位程序的运行架构:$sudoyuminstallxulrunner.i686$su......
  • docker 的overlayFS 文件系统
    referto:https://juejin.cn/post/7112352737051803684一、overlay相关介绍Docker 底层有三驾马车,Namespace、CGroup 和 UnionFS(联合文件系统),UnionFS 是 Docker 镜像的基础。UnionFS(联合文件系统) 是一种分层、轻量级并且高性能的文件系统,它支持对文件系统的修改作为一......
  • 文件上传注入
      、 ......
  • easyExcel读写入csv文件
    写入:Filefile=newFile(System.getProperty("java.io.tmpdir")+File.separator+"aa.csv");ExcelWriterexcelWriter=EasyExcelFactory.write(file).excelType(ExcelTypeEnum.CSV).charset(Charset.forName("GBK"))......