Linux /etc/shadow 超詳細內容解析
/etc/shadow 檔案,用於儲存 系統中使用者的密碼資訊,又稱為“影子檔案”。 |
前面介紹了 /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"
2013年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 密碼。
原文地址:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31559985/viewspace-2687044/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Linux系統中的/etc/shadow檔案超詳細內容解析Linux
- /etc/passwd & /etc/shadow 詳解
- 超詳細 DNS 協議解析DNS協議
- 內地到香港抽血鑑定性別流程超全超詳細_容媽媽網
- linux命令yum的詳細解析Linux
- 超詳細SAP HANA JOB全解析
- 超詳細的Eureka原始碼解析原始碼
- 超詳細的Ribbon原始碼解析原始碼
- 分享Linux下的sudo及其配置檔案/etc/sudoers詳細配置Linux
- MyBatis 核心配置檔案詳細內容詳解MyBatis
- RabbitMQ超詳細安裝教程(Linux)MQLinux
- 詳解Linux中/etc/passwd檔案Linux
- C語言運算子深度解析--超詳細C語言
- 超詳細的ArrayList擴容過程(配合原始碼詳解)原始碼
- /etc/shadow檔案相關欄位的解釋
- Vue(13)子元件與父元件超詳細解析Vue元件
- linux shell 指令碼語言教程(超詳細!)Linux指令碼
- Android技能樹 — 網路小結(6)之 OkHttp超超超超超超超詳細解析AndroidHTTP
- Linux系統超詳細Linux設定靜態IP教程!Linux
- Linux系統環境變數檔案解析(etc/profile ,/etc/bashrc ,~/.bash_profile)Linux變數
- RxLifecycle詳細解析
- 超詳細,手把手教你入門.NET for LinuxLinux
- poi解析Excel內容Excel
- Kali Linux 更換國內映象源詳細教程Linux
- 8.JVM記憶體分配機制超詳細解析JVM記憶體
- 超詳細解析微服務架構,寫得太好了!微服務架構
- linux伺服器安裝svn超詳細介紹Linux伺服器
- CoreLocation框架詳細解析框架
- Semaphore最詳細解析
- JWT 超詳細分析JWT
- MyBatis 關於查詢語句上配置的詳細內容MyBatis
- maven超級pom內容Maven
- CSSbox-shadow詳解CSS
- Postman 安裝與漢化超詳細步驟全解析教程Postman
- 【超詳細】Linux常用命令,這些你需要掌握!Linux
- Android UI——SpannableString詳細解析AndroidUI
- Hadoop Yarn框架詳細解析HadoopYarn框架
- scala模式匹配詳細解析模式