chmod----改變一個或多個檔案的存取模式(mode)
阿新 • • 發佈:2019-01-11
chmod [options] mode files
只能檔案屬主或特權使用者才能使用該功能來改變檔案存取模式。mode可以是數字形式或以who opcode permission形式表示。who是可選的,預設是a(所有使用者)。只能選擇一個opcode(操作碼)。可指定多個mode,以逗號分開。
options:
-c,--changes
只輸出被改變檔案的資訊
-f,--silent,--quiet
當chmod不能改變檔案模式時,不通知檔案的使用者
--help
輸出幫助資訊。
-R,--recursive
可遞迴遍歷子目錄,把修改應到目錄下所有檔案和子目錄
--reference=filename
參照filename的許可權來設定許可權
-v,--verbose
無論修改是否成功,輸出每個檔案的資訊
--version
輸出版本資訊。
who
u
使用者
g
組
o
其它
a
所有使用者(預設)
opcode
+
增加許可權
-
刪除許可權
=
重新分配許可權
permission
r
讀
w
寫
x
執行
s
設定使用者(或組)的ID號
t
設定粘著位(sticky bit),防止檔案或目錄被非屬主刪除
u
使用者的當前許可權
g
組的當前許可權
o
其他使用者的當前許可權
作為選擇,我們多數用三位八進位制數字的形式來表示許可權,第一位指定屬主的許可權,第二位指定組許可權,第三位指定其他使用者的許可權,每位通過4(讀)、2(寫)、1(執行)三種數值的和來確定許可權。如6(4+2)代表有讀寫權,7(4+2+1)有讀、寫和執行的許可權。
還可設定第四位,它位於三位許可權序列的前面,第四位數字取值是4,2,1,代表意思如下:
4,執行時設定使用者ID,用於授權給基於檔案屬主的程序,而不是給建立此程序的使用者。
2,執行時設定使用者組ID,用於授權給基於檔案所在組的程序,而不是基於建立此程序的使用者。
1,設定粘著位。
例項:
$ chmod u+x file 給file的屬主增加執行許可權
$ chmod 751 file 給file的屬主分配讀、寫、執行(7)的許可權,給file的所在組分配讀、執行(5)的許可權,給其他使用者分配執行(1)的許可權
$ chmod u=rwx,g=rx,o=x file 上例的另一種形式
$ chmod =r file 為所有使用者分配讀許可權
$ chmod 444 file 同上例
$ chmod a-wx,a+r file 同上例
$ chmod -R u+r directory 遞迴地給directory目錄下所有檔案和子目錄的屬主分配讀的許可權
$ chmod 4755 設定用ID,給屬主分配讀、寫和執行許可權,給組和其他使用者分配讀、執行的許可權。