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

<p ><strong>1. /etc/passwd文件</strong></p><p >  </p><p >  <strong>1.1 /etc/passwd文件内容格式</strong></p><p >    用户名: 密码 : uid : gid :用户描述:主目录:登陆shell</p><p >    举个例子:</p><p >    </p><table width="901"><tbody ><tr class="firstRow"><td class="gutter" width="35"><div class="line number1 index0 alt2" >1</div><div class="line number2 index1 alt1" >2</div><div class="line number3 index2 alt2" >3</div><div class="line number4 index3 alt1" >4</div><div class="line number5 index4 alt2" >5</div><div class="line number6 index5 alt1" >6</div><div class="line number7 index6 alt2" >7</div><div class="line number8 index7 alt1" >8</div><div class="line number9 index8 alt2" >9</div><div class="line number10 index9 alt1" >10</div><div class="line number11 index10 alt2" >11</div><div class="line number12 index11 alt1" >12</div></td><td class="code" width="NaN"><div class="line number1 index0 alt2" ><code class="java plain" >#cat /etc/passwd</code><code class="java comments" >//利用cat命令打开查看passwd内容</code></div><div class="line number2 index1 alt1" ><code class="java plain" >root:x:</code><code class="java value" >0</code><code class="java plain" >:</code><code class="java value" >0</code><code class="java plain" >:Superuser:/:</code></div><div class="line number3 index2 alt2" ><code class="java plain" >daemon:x:</code><code class="java value" >1</code><code class="java plain" >:</code><code class="java value" >1</code><code class="java plain" >:Systemdaemons:/etc:</code></div><div class="line number4 index3 alt1" ><code class="java plain" >bin:x:</code><code class="java value" >2</code><code class="java plain" >:</code><code class="java value" >2</code><code class="java plain" >:Ownerofsystemcommands:/bin:</code></div><div class="line number5 index4 alt2" ><code class="java plain" >sys:x:</code><code class="java value" >3</code><code class="java plain" >:</code><code class="java value" >3</code><code class="java plain" >:Ownerofsystemfiles:/usr/sys:</code></div><div class="line number6 index5 alt1" ><code class="java plain" >adm:x:</code><code class="java value" >4</code><code class="java plain" >:</code><code class="java value" >4</code><code class="java plain" >:Systemaccounting:/usr/adm:</code></div><div class="line number7 index6 alt2" ><code class="java plain" >uucp:x:</code><code class="java value" >5</code><code class="java plain" >:</code><code class="java value" >5</code><code class="java plain" >:UUCPadministrator:/usr/lib/uucp:</code></div><div class="line number8 index7 alt1" ><code class="java plain" >auth:x:</code><code class="java value" >7</code><code class="java plain" >:</code><code class="java value" >21</code><code class="java plain" >:Authenticationadministrator:/tcb/files/auth:</code></div><div class="line number9 index8 alt2" ><code class="java plain" >cron:x:</code><code class="java value" >9</code><code class="java plain" >:</code><code class="java value" >16</code><code class="java plain" >:Crondaemon:/usr/spool/cron:</code></div><div class="line number10 index9 alt1" ><code class="java plain" >listen:x:</code><code class="java value" >37</code><code class="java plain" >:</code><code class="java value" >4</code><code class="java plain" >:Networkdaemon:/usr/net/nls:</code></div><div class="line number11 index10 alt2" ><code class="java plain" >lp:x:</code><code class="java value" >71</code><code class="java plain" >:</code><code class="java value" >18</code><code class="java plain" >:Printeradministrator:/usr/spool/lp:</code></div><div class="line number12 index11 alt1" ><code class="java plain" >sam:x:</code><code class="java value" >200</code><code class="java plain" >:</code><code class="java value" >50</code><code class="java plain" >:Samsan:/usr/sam:/bin/sh</code></div></td></tr></tbody></table><p ><strong>用户名:</strong>每个用户的标识字符串</p><p ><strong>密码:</strong>这里的x表示是暗文显示。如果是其他什么数字,就代表是密码明文。</p><p ><strong>uid:</strong>每个用户必须被分配一个userid,”0”为root保留ID.<span >1-99为系统保留,分配给系统预定义帐号</span>。Linux<span >用户可以分为</span><span >3</span><span >类:超级用户(</span><span >root</span><span >用户标识号是</span><span >0</span><span >)、管理用户和普通用户。</span></p><pre >系统中有一类用户称为伪用户(psuedousers),这些用户在/etc/passwd文件中也占有一条记录,但是不能登录,因为它们的登录Shell为空。 它们的存在主要是方便系统管理,满足相应的系统进程对文件属主的要求。</pre><p >  /etc/passwd文件中常见的伪用户</p><table><tbody><tr class="firstRow"><td valign="top" width="128" ><p><span >伪 用 户</span></p></td><td valign="top" width="218" ><p><span >含 义</span></p></td></tr><tr><td valign="top" width="128" ><p><span >bin</span></p></td><td valign="top" width="218" ><p><span >拥有可执行的用户命令文件</span></p></td></tr><tr><td valign="top" width="128" ><p><span >sys</span></p></td><td valign="top" width="218" ><p><span >拥有系统文件</span></p></td></tr><tr><td valign="top" width="128" ><p><span >adm</span></p></td><td valign="top" width="218" ><p><span >拥有帐户文件</span></p></td></tr><tr><td valign="top" width="128" ><p><span >uucp</span></p></td><td valign="top" width="218" ><p><span >UUCP使用</span></p></td></tr><tr><td valign="top" width="128" ><p><span >lp</span></p></td><td valign="top" width="218" ><p><span >lp或lpd子系统使用</span></p></td></tr><tr><td valign="top" width="128" ><p><span >nobody</span></p></td><td valign="top" width="218" ><p><span >NFS使用</span></p></td></tr></tbody></table><p><span >  除了上面列出的伪用户外,还有许多标准的伪用户,例如:audit, cron, mail, usenet等,它们也都各自为相关的进程和文件所需要。</span></p><p></p><p><strong>gid :</strong>字段记录的是用户所属的用户组。它对应着/etc/group文件中的一条记录。</p><p ><strong>  </strong></p><p ><strong>用户描述:</strong>字段记录着用户的一些个人情况,例如用户的真实姓名、电话、地址等,这个字段并没有什么实际的用途。</p><p ><strong>主目录:</strong>用户的起始工作目录,它是用户在登录到系统之后所处的目录。在大多数系统中,各用户的主目录都被组织在同一个特定的目录下,而用户主目录的名称就是该用户的登录名。各用户对自己的主目录有读、写、执行(搜索)权限,其他用户对此目录的访问权限则根据具体情况设置。</p><p ><strong>登陆shell:</strong>用户登录后,要启动一个进程,负责将用户的操作传给内核,这个进程是用户登录到系统后运行的命令解释器或某个特定的程序,即Shell。Shell是用户与Linux系统之间的接口。Linux的Shell有许多种,每种都有不同的特点。常用的有sh(BourneShell),csh(CShell),ksh(KornShell),tcsh(TENEX/TOPS-20typeCShell),bash(BourneAgainShell)等。系统管理员可以根据系统情况和用户习惯为用户指定某个Shell。如果不指定Shell,那么系统使用sh为默认的登录Shell,即这个字段的值为/bin/sh。</p><p >若此处shell为:/sbin/nologin,则代表这个用户不能登录。这样做的好处是,ftp用户只能通过ftp登录ftp服务器,而不能登录到shell中。</p><p ><strong>2. /etc/shadow 文件内容格式</strong></p><p >  Linux中/etc/shadow<span >文件中的记录行与</span><span >/etc/passwd</span><span >中的一一对应,它由</span><span >pwconv</span><span >命令根据</span><span >/etc/passwd</span><span >中的数据自动产生。它的文件格式与</span><span >/etc/passwd</span><span >类似,由若干个字段组成,字段之间用</span><span >“:”</span><span >隔开</span>,文件的每行是<span >8</span><span >个冒号分割的</span><span >9</span><span >个域,格式如下:</span></p><p >username:passwd:lastchg:min:max:warn:inactive:expire:flag</p><p >登录名<span >:</span><span >加密口令</span><span >:</span><span >最后一次修改时间</span><span >:</span><span >最小时间间隔</span><span >:</span><span >最大时间间隔</span><span >:</span><span >警告时间</span><span >:</span><span >不活动时间</span><span >:</span><span >失效时间</span><span >:</span><span >标志</span></p><p ></p><table width="1064"><tbody ><tr class="firstRow"><td class="gutter" width="35"><div class="line number1 index0 alt2" >1</div><div class="line number2 index1 alt1" >2</div><div class="line number3 index2 alt2" >3</div><div class="line number4 index3 alt1" >4</div><div class="line number5 index4 alt2" >5</div><div class="line number6 index5 alt1" >6</div><div class="line number7 index6 alt2" >7</div><div class="line number8 index7 alt1" >8</div></td><td class="code" width="NaN"><div class="line number1 index0 alt2" ><code class="java value" >1</code><code class="java plain" >)“登录名”是与/etc/passwd文件中的登录名相一致的用户账号</code></div><div class="line number2 index1 alt1" ><code class="java value" >2</code><code class="java plain" >)“口令”字段存放的是加密后的用户口令字,长度为</code><code class="java value" >13</code><code class="java plain" >个字符。如果为空,则对应用户没有口令,登录时不需要口令;如果含有不属于集合{./</code><code class="java value" >0</code><code class="java plain" >-9A-Za-z}中的字符,则对应的用户不能登录。</code></div><div class="line number3 index2 alt2" ><code class="java value" >3</code><code class="java plain" >)“最后一次修改时间”表示的是从某个时刻起,到用户最后一次修改口令时的天数。时间起点对不同的系统可能不一样。例如在SCOLinux中,这个时间起点是</code><code class="java value" >1970</code><code class="java plain" >年</code><code class="java value" >1</code><code class="java plain" >月</code><code class="java value" >1</code><code class="java plain" >日。</code></div><div class="line number4 index3 alt1" ><code class="java value" >4</code><code class="java plain" >)“最小时间间隔”指的是两次修改口令之间所需的最小天数。</code></div><div class="line number5 index4 alt2" ><code class="java value" >5</code><code class="java plain" >)“最大时间间隔”指的是口令保持有效的最大天数。</code></div><div class="line number6 index5 alt1" ><code class="java value" >6</code><code class="java plain" >)“警告时间”字段表示的是从系统开始警告用户到用户密码正式失效之间的天数。</code></div><div class="line number7 index6 alt2" ><code class="java value" >7</code><code class="java plain" >)“不活动时间”表示的是用户没有登录活动但账号仍能保持有效的最大天数。</code></div><div class="line number8 index7 alt1" ><code class="java value" >8</code><code class="java plain" >)“失效时间”字段给出的是一个绝对的天数,如果使用了这个字段,那么就给出相应账号的生存期。期满后,该账号就不再是一个合法的账号,也就不能再用来登录了。</code></div></td></tr></tbody></table>
RangeTime:0.010563s
RangeMem:215.58 KB
返回顶部 留言