chmod命令用法詳解-chmod修改目錄權限


chmod用法:

用來修改某個目錄或文件的訪問權限。 Linux中chmod命令

語法:

chmod [-cfvR] [--help] [--version] [who] [+ | - | =] [mode] 文件名

例子:

chmod -R 777 /home/linux

權限范圍的表示法如下:

u User,即文件或目錄的擁有者;
g Group,即文件或目錄的所屬群組;
o Other,除了文件或目錄擁有者或所屬群組之外,其他用戶皆屬於這個范圍;
a All,即全部的用戶,包含擁有者,所屬群組以及其他用戶;
r 讀取權限,數字代號為“4”;
w 寫入權限,數字代號為“2”;
x 執行或切換權限,數字代號為“1”;
- 不具任何權限,數字代號為“0”;
s 特殊功能說明:變更文件或目錄的權限。

命令中各選項的含義為: 

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

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

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

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

  --help : 顯示輔助說明 

  --version : 顯示版本

操作對象who可是下述字母中的任一個或者它們的組合:

   u 表示“用戶(user)”,即文件或目錄的所有者。

   g 表示“同組(group)用戶”,即與文件屬主有相同組ID的所有用戶。

   o 表示“其他(others)用戶”。

   a 表示“所有(all)用戶”。它是系統默認值。

操作符號可以是:

   + 添加某個權限。

   - 取消某個權限。

   = 賦予給定權限並取消其他所有權限(如果有的話)。

設置 mode 所表示的權限可用下述字母的任意組合:

   r 可讀。

   w 可寫。

    x 可執行。

   X 只有目標文件對某些用戶是可執行的或該目標文件是目錄時才追加x 屬性。

   s 在文件執行時把進程的屬主或組ID置為該文件的文件屬主。

       方式“u+s”設置文件的用戶ID位,“g+s”設置組ID位。

   t 保存程序的文本到交換設備上。

   u 與文件屬主擁有一樣的權限。

   g 與和文件屬主同組的用戶擁有一樣的權限。

   o 與其他用戶擁有一樣的權限。

文件名:以空格分開的要改變權限的文件列表,支持通配符。

r 代表讀,w 代表寫,x 代表執行,

如果可讀,權限是二進制的100,十進制是4;

如果可寫,權限是二進制的010,十進制是2;

如果可運行,權限是二進制的001,十進制是1;

 

具備多個權限,就把相應的 4、2、1 相加就可以了:

若要 rwx 則 4+2+1=7

若要 rw- 則 4+2=6

若要 r-x 則 4+1=5

若要 r-- 則 =4

若要 -wx 則 2+1=3

若要 -w- 則 =2

若要 --x 則 =1

若要 --- 則 =0

實例

將文件 1.txt 設為所有人皆可讀取 :

chmod ugo+r 1.txt

將文件 file1.txt 設為所有人皆可讀取 :

chmod a+r 1.txt

將文件 1.txt 與 2.txt 設為該文件擁有者,與其所屬同一個群體者可寫入,但其他以外的人則不可寫入 :

chmod ug+w,o-w 1.txt 2.txt

將 1.py 設定為只有該文件擁有者可以執行 :

chmod u+x 1.py

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

chmod -R a+r *

此外chmod也可以用數字來表示權限如 :

chmod 777 file

語法為:

chmod abc file

linux中chmod權限的用法

 

chmod ABC file

其中A、B、C各為一個數字,分別表示User、Group、及Other的權限。

A、B、C這三個數字如果各自轉換成由“0”、“1”組成的二進制數,則二進制數的每一位分別代表一個角色的讀、寫、運行的權限。比如User組的權限A:

如果可讀、可寫、可運行,就表示為二進制的111,轉換成十進制就是7。

如果可讀、可寫、不可運行,就表示為二進制的110,轉換成十進制就是6。

如果可讀、不可寫、可運行,就表示為二進制的101,轉換成十進制就是5。

一些人說的“4=r,2=w,1=x”的意思是:

為不同的角色分配不同的權限,放在一起,就出現 777、677這樣的數字了。 

你也可以用 chmod u+x  file  的方式為User組添加運行權限。


 

指令名稱 : 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[] 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) - 所有用戶可讀該目錄,但只有屬主才能改變目錄中的內容。
--------------------------------------------------------------------------
運行 .sh 文件類型的文件:
用file命令測試一下看是什么類型的
file xxxx.sh
如果是Bourne-Again shell script 可以sh xxxx.sh 或者chmod +x xxxx.sh 再./xxx.sh
一般 .sh 的直接添加x(可執行屬性) chmod +x xxx.sh 然后./xxx.sh就可以了
chmod是一個改變用戶擁有指定文件的權限的命令.r:只讀,w:寫,x執行.也可以用數字
--------------------------------------------------------------------------


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM