linux的chmod命令使用詳解

2021-05-22 19:17:03 字數 3444 閱讀 3206

在unix和linux的各種作業系統下,每個檔案(資料夾也被看作是檔案)都按讀、寫、執行設定許可權。

例如我用ls -l命令列檔案表時,得到如下輸出:

-rw-r--r-- 1 bu users 2254 2006-05-20 13:47 tt.htm

從第二個字元起rw-是說使用者bu有讀、寫權,沒有執行權,接著的r--表示使用者組users只有讀許可權,沒有執行權,最後的r--指其他人 (others)只有讀許可權,沒有寫權和執行權。這是系統預設設定,我可以改寫tt.htm,同組的人和其他人只有權讀,沒人有權執行,因為只是乙個 html檔案,不必執行。這在novell的directory services之前很先進。

讀、寫、執行三項許可權可以用數字表示,就是r=4,w=2,x=1。所以,上面的例子中的rw-r--r--用數字表示成644。

反過來說777就是rwxrwxrwx,意思是該登入使用者(可以用命令id檢視)、他所在的組和其他人都有最高許可權。

再多說一句。我用chmod o-r tt.htm命令改許可權,o-r是others的許可權中減掉讀。結果是

-rw-r----- 1 bu users 2254 2006-05-20 13:47 tt.htm

如果用命令chmod 777 tt.htm,結果是

-rwxrwxrwx 1 bu users 2254 2006-05-20 13:47 tt.htm

任何人都有讀、寫、執行三項許可權。

指令名稱 : chmod

使用許可權 : 所有使用者

使用方式 : chmod [-cfvr] [--help] [--version] mode file...

說明 : linux/unix 的檔案訪問許可權分為** : 檔案擁有者、群組、其他。利用 chmod 可以藉

以控制檔案如何被他人所訪問。

把計 :

mode : 許可權設定字串,格式如下 : [ugoa...][[+-=][rwxx]...][,...],其中u 表示該檔案的擁有

者,g 表示與該檔案的擁有者屬於同乙個群體(group)者,o 表示其他以外的人,a 表示這三者皆

是。+ 表示增加許可權、- 表示取消許可權、= 表示唯一設定許可權。

r 表示可讀取,w 表示可寫入,x 表示可執行,x 表示只有當該檔案是個子目錄或者該檔案已經被

設定過為可執行。

-c : 若該檔案許可權確實已經更改,才顯示其更改動作

-f : 若該檔案許可權無法被更改也不要顯示錯誤訊息

-v : 顯示許可權變更的詳細資料

-r : 對目前目錄下的所有檔案與子目錄進行相同的許可權變更(即以遞迴的方式逐個變更)

--help : 顯示輔助說明

--version : 顯示版本

範例 :將檔案 file1.txt 設為所有人皆可讀取 :

chmod ugo+r file1.txt

將檔案 file1.txt 設為所有人皆可讀取 :

chmod a+r file1.txt

將檔案 file1.txt 與 file2.txt 設為該檔案擁有者,與其所屬同乙個群體者可寫入,但其他以外的

人則不可寫入 :

chmod ug+w,o-w file1.txt file2.txt

將 ex1.py 設定為只有該檔案擁有者可以執行 :

chmod u+x ex1.py

將目前目錄下的所有檔案與子目錄皆設為任何人可讀取 :

chmod -r a+r *

此外chmod也可以用數字來表示許可權如 chmod 777 file

語法為:chmod abc file

其中a,b,c各為乙個數字,分別表示user、group、及other的許可權。

r=4,w=2,x=1

若要rwx屬性則4+2+1=7;

若要rw-屬性則4+2=6;

若要r-x屬性則4+1=7。

範例:chmod a=rwx file

和chmod 777 file

效果相同

chmod ug=rwx,o=x file

和chmod 771 file

效果相同

若用chmod 4755 filename可使此程式具有root的許可權

指令名稱 : chown

使用許可權 : root

使用方式 : chmod [-cfhvr] [--help] [--version] user[:group] file...

說明 : linux/unix 是多人多任務作業系統,所有的檔案皆有擁有者。利用 chown 可以將檔案的擁

有者加以改變。一般來說,這個指令只有是由系統管理者(root)所使用,一般使用者沒有許可權可以

改變別人的檔案擁有者,也沒有許可權可以自己的檔案擁有者改設為別人。只有系統管理者(root)才

有這樣的許可權。

把計 :

user : 新的檔案擁有者的使用者 idgroup : 新的檔案擁有者的使用者群體(group)-c : 若該檔案

擁有者確實已經更改,才顯示其更改動作-f : 若該檔案擁有者無法被更改也不要顯示錯誤訊息-h :

只對於鏈結(link)進行變更,而非該 link 真正指向的檔案-v : 顯示擁有者變更的詳細資料-r : 對目

前目錄下的所有檔案與子目錄進行相同的擁有者變更(即以遞迴的方式逐個變更)--help : 顯示輔助

說明--version : 顯示版本

範例 :

將檔案 file1.txt 的擁有者設為 users 群體的使用者 jessie :

chown jessie:users file1.txt

將目前目錄下的所有檔案與子目錄的擁有者皆設為 users 群體的使用者 lamport :

chmod -r lamport:users *

-rw------- (600) -- 只有屬主有讀寫許可權。

-rw-r--r-- (644) -- 只有屬主有讀寫許可權;而屬組使用者和其他使用者只有讀許可權。

-rwx------ (700) -- 只有屬主有讀、寫、執行許可權。

-rwxr-xr-x (755) -- 屬主有讀、寫、執行許可權;而屬組使用者和其他使用者只有讀、執行許可權。

-rwx--x--x (711) -- 屬主有讀、寫、執行許可權;而屬組使用者和其他使用者只有執行許可權。

-rw-rw-rw- (666) -- 所有使用者都有檔案讀、寫許可權。這種做法不可取。

-rwxrwxrwx (777) -- 所有使用者都有讀、寫、執行許可權。更不可取的做法。

以下是對目錄的兩個普通設定:

drwx------ (700) - 只有屬主可在目錄中讀、寫。

drwxr-xr-x (755) - 所有使用者可讀該目錄,但只有屬主才能改變目錄中的內容

suid的代表數字是4,比如4755的結果是-rwsr-xr-x

sgid的代表數字是2,比如6755的結果是-rwsr-sr-x

sticky位代表數字是1,比如7755的結果是-rwsr-sr-t

(當然7755這個chmod設定沒多大意義,這裡只是演示一下) 

chmod命令的使用

指令名稱 chmod 使用許可權 所有使用者 使用方式 chmod cfvr help version mode file.說明 linux unix 的檔案呼叫許可權分為 檔案擁有者 群組 其他。利用 chmod 可以藉以控制檔案如何被他人所呼叫。引數 mode 許可權設定字串,格式如下 ugoa...

chmod命令的使用

chmod命令 修改檔案 目錄許可權 對於檔案或者目錄的普通許可權,共有 3 種,分別為 r 讀取 4 w 寫入 2 x 執行 1 一般格式為 chomd 777 filename rw 600 只有屬主有讀寫許可權。rw r r 644 只有屬主有讀寫許可權 而屬組使用者和其他使用者只有讀許可權。...

Linux命令 chmod命令

chmod命令 改變檔案或目錄的訪問許可權 許可權代號 r 檔案被讀取 4 w 檔案被寫入 2 x 檔案被執行 1 許可權範圍 u 檔案所有者 g 檔案所有者所在組 o 其他 a 全部 建立檔案 touch demo1.txt 顯示建立的檔案 ls l demo1.txt 執行結果 rw rw r ...