溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何解析Linux /etc/shadow

發(fā)布時(shí)間:2021-11-09 10:33:58 來源:億速云 閱讀:158 作者:柒染 欄目:建站服務(wù)器

這篇文章給大家介紹如何解析Linux /etc/shadow,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

/etc/shadow 文件,用于存儲  Linux 系統(tǒng)中用戶的密碼信息,又稱為“影子文件”。

前面介紹了 /etc/passwd 文件,由于該文件允許所有用戶讀取,易導(dǎo)致用戶密碼泄露,因此 Linux 系統(tǒng)將用戶的密碼信息從 /etc/passwd 文件中分離出來,并單獨(dú)放到了此文件中。

/etc/shadow 文件只有 root 用戶擁有讀權(quán)限,其他用戶沒有任何權(quán)限,這樣就保證了用戶密碼的安全性。

注意,如果這個(gè)文件的權(quán)限發(fā)生了改變,則需要注意是否是惡意攻擊。

介紹此文件之前,我們先打開看看,執(zhí)行如下 命令:

[root@localhost ~]#vim /etc/shadow
root: $6$9w5Td6lg
$bgpsy3olsq9WwWvS5Sst2W3ZiJpuCGDY.4w4MRk3ob/i85fl38RH15wzVoom ff9isV1 PzdcXmixzhnMVhMxbvO:15775:0:99999:7:::
bin:*:15513:0:99999:7:::
daemon:*:15513:0:99999:7:::
…省略部分輸出…

同 /etc/passwd 文件一樣,文件中每行代表一個(gè)用戶,同樣使用 ":" 作為分隔符,不同之處在于,每行用戶信息被劃分為 9 個(gè)字段。每個(gè)字段的含義如下:

用戶名:加密密碼:最后一次修改時(shí)間:最小修改時(shí)間間隔:密碼有效期:密碼需要變更前的警告天數(shù):密碼過期后的寬限時(shí)間:賬號失效時(shí)間:保留字段

接下來,給大家分別介紹這 9 個(gè)字段。

用戶名

同 /etc/passwd 文件的用戶名有相同的含義。

加密密碼

這里保存的是真正加密的密碼。目前 Linux 的密碼采用的是 SHA512 散列加密算法,原來采用的是 MD5 或 DES 加密算法。SHA512 散列加密算法的加密等級更高,也更加安全。

注意,這串密碼產(chǎn)生的亂碼不能手工修改,如果手工修改,系統(tǒng)將無法識別密碼,導(dǎo)致密碼失效。很多軟件透過這個(gè)功能,在密碼串前加上 "!"、"*" 或 "x" 使密碼暫時(shí)失效。

所有偽用戶的密碼都是 "!!" 或 "*",代表沒有密碼是不能登錄的。當(dāng)然,新創(chuàng)建的用戶如果不設(shè)定密碼,那么它的密碼項(xiàng)也是 "!!",代表這個(gè)用戶沒有密碼,不能登錄。

最后一次修改時(shí)間

此字段表示最后一次修改密碼的時(shí)間,可是,為什么 root 用戶顯示的是 15775 呢?

這是因?yàn)?,Linux 計(jì)算日期的時(shí)間是以  1970 年 1 月 1 日作為 1 不斷累加得到的時(shí)間,到 1971 年 1 月 1 日,則為 366 天。這里顯示 15775 天,也就是說,此 root 賬號在 1970 年 1 月 1 日之后的第 15775 天修改的 root 用戶密碼。

那么,到底 15775 代表的是哪一天呢?可以使用如下 命令進(jìn)行換算:

[root@localhost ~]# date -d "1970-01-01 15775 days"
2013年03月11日 星期一 00:00:00 CST

可以看到,通過以上命令,即可將其換算為我們習(xí)慣的系統(tǒng)日期。

最小修改時(shí)間間隔

最小修改間隔時(shí)間,也就是說,該字段規(guī)定了從第 3 字段(最后一次修改密碼的日期)起,多長時(shí)間之內(nèi)不能修改密碼。如果是 0,則密碼可以隨時(shí)修改;如果是 10,則代表密碼修改后 10 天之內(nèi)不能再次修改密碼。

此字段是為了針對某些人頻繁更改賬戶密碼而設(shè)計(jì)的。

密碼有效期

經(jīng)常變更密碼是個(gè)好習(xí)慣,為了強(qiáng)制要求用戶變更密碼,這個(gè)字段可以指定距離第 3 字段(最后一次更改密碼)多長時(shí)間內(nèi)需要再次變更密碼,否則該賬戶密碼進(jìn)行過期階段。
該字段的默認(rèn)值為 99999,也就是 273 年,可認(rèn)為是永久生效。如果改為 90,則表示密碼被修改 90 天之后必須再次修改,否則該用戶即將過期。管理服務(wù)器時(shí),通過這個(gè)字段強(qiáng)制用戶定期修改密碼。

密碼需要變更前的警告天數(shù)

與第 5 字段相比較,當(dāng)賬戶密碼有效期快到時(shí),系統(tǒng)會發(fā)出警告信息給此賬戶,提醒用戶 "再過 n 天你的密碼就要過期了,請盡快重新設(shè)置你的密碼!"。

該字段的默認(rèn)值是 7,也就是說,距離密碼有效期的第 7 天開始,每次登錄系統(tǒng)都會向該賬戶發(fā)出 "修改密碼" 的警告信息。

密碼過期后的寬限天數(shù)

也稱為“口令失效日”,簡單理解就是,在密碼過期后,用戶如果還是沒有修改密碼,則在此字段規(guī)定的寬限天數(shù)內(nèi),用戶還是可以登錄系統(tǒng)的;如果過了寬限天數(shù),系統(tǒng)將不再讓此賬戶登陸,也不會提示賬戶過期,是完全禁用。

比如說,此字段規(guī)定的寬限天數(shù)是 10,則代表密碼過期 10 天后失效;如果是 0,則代表密碼過期后立即失效;如果是 -1,則代表密碼永遠(yuǎn)不會失效。

賬號失效時(shí)間

同第 3 個(gè)字段一樣,使用自  1970 年 1 月 1 日以來的總天數(shù)作為賬戶的失效時(shí)間。該字段表示,賬號在此字段規(guī)定的時(shí)間之外,不論你的密碼是否過期,都將無法使用!

該字段通常被使用在具有收費(fèi)服務(wù)的系統(tǒng)中。

保留

這個(gè)字段目前沒有使用,等待新功能的加入。

忘記密碼

經(jīng)常有讀者會忘記自己的賬戶密碼,該怎么處理呢?

對于普通賬戶的密碼遺失,可以通過 root 賬戶解決,它會重新給你配置好指定賬戶的密碼,而不需知道你原有的密碼(利用 root 的身份使用 passwd 命令即可)。

如果 root 賬號的密碼遺失,則需要重新啟動進(jìn)入單用戶模式,系統(tǒng)會提供 root 權(quán)限的 bash 接口,此時(shí)可以用 passwd 命令修改賬戶密碼;也可以通過掛載根目錄,修改 /etc/shadow,將賬戶的 root 密碼清空的方法,此方式可使用 root 無法密碼即可登陸,建議登陸后使用 passwd 命令配置 root 密碼。

關(guān)于如何解析Linux /etc/shadow就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI