Linux中國

如何根據文件許可權查找文件

在 Linux 中查找文件並不是什麼大問題。市面上也有很多可靠的自由開源的可視化查找工具。但對我而言,查找文件,用命令行的方式會更快更簡單。我們已經知道 如何根據訪問和修改文件的時間尋找或整理文件。今天,在基於 Unix 的操作系統中,我們將見識如何通過許可權查找文件。

本段教程中,我將創建三個文件名為 file1file2file3 分別賦予 777766655 文件許可權,並分別置於名為 ostechnix 的文件夾中。

mkdir ostechnix && cd ostechnix/
install -b -m 777 /dev/null file1
install -b -m 766 /dev/null file2
install -b -m 655 /dev/null file3

現在,讓我們通過許可權來查找一下文件。

根據許可權查找文件

根據許可權查找文件最具代表性的語法:

find -perm mode

mode 可以是代表許可權的八進位數字(777、666 …)也可以是許可權符號(u=x,a=r+x)。

在深入之前,我們就以下三點詳細說明 mode 參數。

  1. 如果我們不指定任何參數前綴,它將會尋找具體許可權的文件。
  2. 如果我們使用 - 參數前綴, 尋找到的文件至少擁有 mode 所述的許可權,而不是具體的許可權(大於或等於此許可權的文件都會被查找出來)。
  3. 如果我們使用 / 參數前綴,那麼所有者、組或者其他人任意一個應當享有此文件的許可權。

為了讓你更好的理解,讓我舉些例子。

首先,我們將要看到基於數字許可權查找文件。

基於數字(八進位)許可權查找文件

讓我們運行下列命令:

find -perm 777

這條命令將會查找到當前目錄許可權為確切為 777 許可權的文件。

1

如你看見的屏幕輸出,file1 是唯一一個擁有確切為 777 許可權的文件。

現在,讓我們使用 - 參數前綴,看看會發生什麼。

find -perm -766

如你所見,命令行上顯示兩個文件。我們給 file2 設置了 766 許可權,但是命令行顯示兩個文件,什麼鬼?因為,我們設置了 - 參數前綴。它意味著這條命令將在所有文件中查找文件所有者的「讀/寫/執行」許可權,文件用戶組的「讀/寫」許可權和其他用戶的「讀/寫」許可權。本例中,file1 和 file2 都符合要求。換句話說,文件並不一樣要求時確切的 766 許可權。它將會顯示任何屬於(高於)此許可權的文件 。

然後,讓我們使用 / 參數前置,看看會發生什麼。

find -perm /222

上述命令將會查找某些人(要麼是所有者、用戶組,要麼是其他人)擁有寫許可權的文件。這裡有另外一個例子:

find -perm /220

這條命令會查找所有者或用戶組中擁有寫許可權的文件。這意味著匹配所有者和用戶組任一可寫的文件,而其他人的許可權隨意。

如果你使用 - 前綴運行相同的命令,你只會看到所有者和用戶組都擁有寫許可權的文件。

find -perm -220

下面的截圖會告訴你這兩個參數前綴的不同。

如我之前說過的一樣,我們也可以使用符號表示文件許可權。

請閱讀:

基於符號的文件許可權查找文件

在下面的例子中,我們使用例如 u(所有者)、g(用戶組) 和 o(其他) 的符號表示法。我們也可以使用字母 a 代表上述三種類型。我們可以通過特指的 r (讀)、 w (寫)、 x (執行)分別代表它們的許可權。

例如,尋找用戶組中擁有 許可權的文件,執行:

find -perm -g=w

上面的例子中,file1 和 file2 都擁有 許可權。請注意,你可以等效使用 =+ 兩種符號標識。例如,下列兩行相同效果的代碼。

find -perm -g=w
find -perm -g+w

查找文件所有者中擁有寫許可權的文件,執行:

find -perm -u=w

查找所有用戶中擁有寫許可權的文件,執行:

find -perm -a=w

查找所有者和用戶組中同時擁有寫許可權的文件,執行:

find -perm -g+w,u+w

上述命令等效與 find -perm -220

查找所有者或用戶組中擁有寫許可權的文件,執行:

find -perm /u+w,g+w

或者,

find -perm /u=w,g=w

上述命令等效於 find -perm /220

更多詳情,參照 man 手冊。

man find

了解更多簡化案例或其他 Linux 命令,查看man 手冊

然後,這就是所有的內容。希望這個教程有用。更多乾貨,敬請關注。

乾杯!

via: https://www.ostechnix.com/find-files-based-permissions/

作者:SK 譯者:CYLeft 校對:校對者ID

本文由 LCTT 原創編譯,Linux中國 榮譽推出


本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive

對這篇文章感覺如何?

太棒了
0
不錯
0
愛死了
0
不太好
0
感覺很糟
0
雨落清風。心向陽

    You may also like

    Leave a reply

    您的郵箱地址不會被公開。 必填項已用 * 標註

    這個站點使用 Akismet 來減少垃圾評論。了解你的評論數據如何被處理

    More in:Linux中國

    Linux中國

    捐贈 Let's Encrypt,共建安全的互聯網

    隨著 Mozilla、蘋果和谷歌對沃通和 StartCom 這兩家 CA 公司處罰落定,很多使用這兩家 CA 所簽發證書的網站紛紛尋求新的證書籤發商。有一個非盈利組織可以為大家提供了免費、可靠和安全的 SSL 證書服務,這就是 Let's Encrypt 項目。現在,它需要您的幫助
    Linux中國

    關於Linux防火牆iptables的面試問答

    Nishita Agarwal是Tecmint的用戶,她將分享關於她剛剛經歷的一家公司(印度的一家私人公司Pune)的面試經驗。在面試中她被問及許多不同的問題,但她是iptables方面的專家,因此她想分享這些關於iptables的問題和相應的答案給那些以後可能會進行相關面試的人。 所有的問題和相應的答案都基於Nishita Agarwal的記憶並經過了重寫。 嗨,朋友!我叫Nishita Agarwal。我已經取得了理學學士學位,我的專業集中在UNIX和它的變種(BSD,Linux)。它們一直深深的吸引著我。我在存儲方面有1年多的經驗。我正在尋求職業上的變化,並將供職於印度的P
    Linux中國

    Lets Encrypt 已被所有主流瀏覽器所信任

    旨在讓每個網站都能使用 HTTPS 加密的非贏利組織 Lets Encrypt 已經得了 IdenTrust的交叉簽名,這意味著其證書現在已經可以被所有主流的瀏覽器所信任。從這個裡程碑事件開始,訪問者訪問使用了Lets Encrypt 證書的網站不再需要特別配置就可以得到 HTTPS 安全保護了。 Lets Encrypt 的兩個中級證書 ...