如何根據文件權限查找文件
在 Linux 中查找文件并不是什么大問題。市面上也有很多可靠的自由開源的可視化查找工具。但對我而言,查找文件,用命令行的方式會更快更簡單。我們已經知道 如何根據訪問和修改文件的時間尋找或整理文件。今天,在基于 Unix 的操作系統中,我們將見識如何通過權限查找文件。
本段教程中,我將創建三個文件名為 file1
,file2
和 file3
分別賦予 777
,766
和 655
文件權限,并分別置于名為 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 參數。
- 如果我們不指定任何參數前綴,它將會尋找具體權限的文件。
- 如果我們使用
-
參數前綴, 尋找到的文件至少擁有 mode 所述的權限,而不是具體的權限(大于或等于此權限的文件都會被查找出來)。 - 如果我們使用
/
參數前綴,那么所有者、組或者其他人任意一個應當享有此文件的權限。
為了讓你更好的理解,讓我舉些例子。
首先,我們將要看到基于數字權限查找文件。
基于數字(八進制)權限查找文件
讓我們運行下列命令:
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 手冊。
然后,這就是所有的內容。希望這個教程有用。更多干貨,敬請關注。
干杯!