Linux etc shadow 超詳細內容解析

2021-10-05 22:02:02 字數 2830 閱讀 6027

/etc/shadow 檔案,用於儲存 linux 系統中使用者的密碼資訊,又稱為「影子檔案」。

前面介紹了 /etc/passwd 檔案,由於該檔案允許所有使用者讀取,易導致使用者密碼洩露,因此 linux 系統將使用者的密碼資訊從 /etc/passwd 檔案中分離出來,並單獨放到了此檔案中。

/etc/shadow 檔案只有 root 使用者擁有讀許可權,其他使用者沒有任何許可權,這樣就保證了使用者密碼的安全性。

注意,如果這個檔案的許可權發生了改變,則需要注意是否是惡意攻擊。

介紹此檔案之前,我們先開啟看看,執行如下命令:

[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 檔案一樣,檔案中每行代表乙個使用者,同樣使用 ":" 作為分隔符,不同之處在於,每行使用者資訊被劃分為 9 個字段。每個欄位的含義如下:

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

使用者名稱

同 /etc/passwd 檔案的使用者名稱有相同的含義。

加密密碼

這裡儲存的是真正加密的密碼。目前 linux 的密碼採用的是 sha512 雜湊加密演算法,原來採用的是 md5 或 des 加密演算法。sha512 雜湊加密演算法的加密等級更高,也更加安全。

注意,這串密碼產生的亂碼不能手工修改,如果手工修改,系統將無法識別密碼,導致密碼失效。很多軟體透過這個功能,在密碼串前加上 "!"、"*" 或 "x" 使密碼暫時失效。

所有偽使用者的密碼都是 "!!" 或 "*",代表沒有密碼是不能登入的。當然,新建立的使用者如果不設定密碼,那麼它的密碼項也是 "!!",代表這個使用者沒有密碼,不能登入。

最後一次修改時間

此欄位表示最後一次修改密碼的時間,可是,為什麼 root 使用者顯示的是 15775 呢?

這是因為,linux 計算日期的時間是以  1970 年 1 月 1 日作為 1 不斷累加得到的時間,到 1971 年 1 月 1 日,則為 366 天。這裡顯示 15775 天,也就是說,此 root 賬號在 1970 年 1 月 1 日之後的第 15775 天修改的 root 使用者密碼。

那麼,到底 15775 代表的是哪一天呢?可以使用如下命令進行換算:

[root@localhost ~]# date -d "1970-01-01 15775 days"

2023年03月11日 星期一 00:00:00 cst

可以看到,通過以上命令,即可將其換算為我們習慣的系統日期。

最小修改時間間隔

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

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

密碼有效期

經常變更密碼是個好習慣,為了強制要求使用者變更密碼,這個字段可以指定距離第 3 字段(最後一次更改密碼)多長時間內需要再次變更密碼,否則該賬戶密碼進行過期階段。

該字段的預設值為 99999,也就是 273 年,可認為是永久生效。如果改為 90,則表示密碼被修改 90 天之後必須再次修改,否則該使用者即將過期。管理伺服器時,通過這個字段強制使用者定期修改密碼。

密碼需要變更前的警告天數

與第 5 欄位相比較,當賬戶密碼有效期快到時,系統會發出警告資訊給此賬戶,提醒使用者 "再過 n 天你的密碼就要過期了,請盡快重新設定你的密碼!"。

該字段的預設值是 7,也就是說,距離密碼有效期的第 7 天開始,每次登入系統都會向該賬戶發出 "修改密碼" 的警告資訊。

密碼過期後的寬限天數

也稱為「口令失效日」,簡單理解就是,在密碼過期後,使用者如果還是沒有修改密碼,則在此字段規定的寬限天數內,使用者還是可以登入系統的;如果過了寬限天數,系統將不再讓此賬戶登陸,也不會提示賬戶過期,是完全禁用。

比如說,此欄位規定的寬限天數是 10,則代表密碼過期 10 天後失效;如果是 0,則代表密碼過期後立即失效;如果是 -1,則代表密碼永遠不會失效。

賬號失效時間

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

該欄位通常被使用在具有收費服務的系統中。

保留

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

忘記密碼怎麼辦

經常有讀者會忘記自己的賬戶密碼,該怎麼處理呢?

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

如果 root 賬號的密碼遺失,則需要重新啟動進入單使用者模式,系統會提供 root 許可權的 bash 介面,此時可以用 passwd 命令修改賬戶密碼;也可以通過掛載根目錄,修改 /etc/shadow,將賬戶的 root 密碼清空的方法,此方式可使用 root 無法密碼即可登陸,建議登陸後使用 passwd 命令配置 root 密碼。

Linux etc shadow 超詳細內容解析

etc shadow 檔案,用於儲存 linux 系統中使用者的密碼資訊,又稱為 影子檔案 前面介紹了 etc passwd 檔案,由於該檔案允許所有使用者讀取,易導致使用者密碼洩露,因此 linux 系統將使用者的密碼資訊從 etc passwd 檔案中分離出來,並單獨放到了此檔案中。etc sh...

超網 超網各類說明

超網的劃分 示例 某企業有乙個網段,該網段有200臺主機,使用192.168.0.0 255.255.255.0網段。後來計算機數量增加到400臺,為後來增加的200臺主機使用192.168.1.0 255.255.255.0網段,如下圖 在路由器配置了192.168.0.1的ip位址介面,再新增1...

HTML標籤學習 超基礎 超easy

文字標籤 和文字有關的標籤 b 字型加粗 i 字型斜體 font 標籤列表標籤無序列表 鏈結標籤 div和span 語義化標籤 html5中為了提高程式的可讀性,提供了一些標籤 標籤 tr 定義行 背景色,對齊方式 td 定義單元格 th 定義表頭單元格 caption 標題 thead 的頭部分 ...