使用ls -l命令後,我們可以看到文件前面都有一串類似-rwxrwxrwx的東西,這一串字符就代表了文件的權限.
三組三位rwx分別代表的是所有者(owner)/群組(group)/其他人(others)的可讀(r)/可寫(w)/可執行權限(x).
e.g., `-rwxrw-r--`就代表所有者擁有讀/寫/執行的權限,群組成員有讀/寫權限,而其他人只有可讀權限.
接下來就講講怎麼使用chmod命令來改變文件的權限.
使用數字改變權限
chmod用數字改變權限的格式為
復制代碼代碼如下:
chmod NUM FILE
Linux裡將上面的rwx分別進行賦值,r為4,w為2,x為1.則對應使用者用戶所具有的權限就是擁有權限代表數字之和.
e.g., 擁有讀/寫權限的話就是 4 + 2 = 6. 擁有讀/執行權限的話就是 4 + 1 = 5.
將`-rwxrw-r--`轉化為數字的話就是`764`
在上面的表達格式裡面可以看到[0-7],就是用數字來改變命令權限.
e.g., 將a文就的所用權限賦給所有用戶,寫法就是 `chmod 777 a`.
這樣所有的用戶就有了讀/寫/執行的權限了.
使用符號改變文件權限
chmod用符號來改變權限的格式為
復制代碼代碼如下:
chmod USER OPTION AUTHORITY FILE
USER這一塊可以為:
u: 擁有者
g: 群組成員
o: 其他人
a: 所有人
OPTION這一塊可以為:
+: 添加權限
-: 除去權限
=: 設定權限
AUTHORITY這一塊可以為:
r: 可讀權限
w: 可寫權限
x: 可執行權限
對於不同對象的操作用逗號隔開,中間不能添加空格.
e.g., 對於b文件,給擁有者添加rwx權限,給群組使用者和其他人添加r權限,然後給群組添加w權限,隨後除去所有人的可讀權限.
復制代碼代碼如下:
chmod u=rwx,go=r,g+w,a-r b
參數介紹
-v, --verbose 對每一個涉及到的文件輸出一個報告.
-c, --changes 同上,不過只有在修改時才輸出.
-f, --silent, --quiet 屏蔽大多數的錯誤信息.
-R, --recursive 遞歸應用,將目錄中的子內容同時應用該權限設置.
chmod命令實例1:在unix中使文件屬性只讀
在這個chmod命令的例子中我們將會知道如何使得一個文件只對其擁有者有只讀權限。在隨後的例子之中,你也可以給予組成員或其他類型成員讀的權限而文件擁有者有寫的權限。
復制代碼代碼如下:
example@localhost~/test ls -lrt stock_trading_systems
-rwxrwxrwx 1 example Domain Users 0 Jul 15 11:42 stock_trading_systems*
#這裡可以看出 所有的用戶類型對 stock_trading_systems這個文件擁有讀、寫及執行的權限
example@localhost~/test chmod 400 stock_trading_systems
#400 表示 100 000 000,也就是指 r-- --- --- 即是只有文件擁有者有讀的權限
example@localhost~/test ls -lrt stock_trading_systems
-r-------- 1 example Domain Users 0 Jul 15 11:42 stock_trading_systems
#現在文件只有讀的屬性,並且只有文件擁有者才能讀它 “ -r--------"
chmod命令實例2:只對擁有者、所在組成員或者其他類的權限進行修改
在這個chmod命令例子之中,我們將會知道如何在擁有者、所在組和其他類型的級別來改變文件權限。你也可以很簡單的改變這其中任意類型的成員對文件的權限。如果你使用文本格式,那麼’u‘表示文件文件擁有者,‘o’表示其他類型,‘g’表示所在組。同時‘r’表示可讀,‘w’表示可寫,‘x’表示可執行。+表示增加權限,-表示移除權限。
復制代碼代碼如下:
example@localhost~/test ls -lrt chmod_examples
-r-------- 1 example Domain Users 0 Jul 15 11:42 chmod_examples
example@localhost~/test chmod u+w chmod_examples
example@localhost~/test ls -lrt chmod_examples
-rw------- 1 example Domain Users 0 Jul 15 11:42 chmod_examples
下面讓我們使用chmod命令來只對組成員的文件權限進行修改
復制代碼代碼如下:
example@localhost~/test ls -lrt chmod_examples
-rw------- 1 example Domain Users 0 Jul 15 11:42 chmod_examples
example@localhost~/test chmod g+w chmod_examples
example@localhost~/test ls -lrt chmod_examples
-rw--w---- 1 example Domain Users 0 Jul 15 11:42 chmod_examples
在這個chmod例子中我們將會僅改變其他類型對文件的權限但不影響文件擁有者以及擁有者所在組的權限。
復制代碼代碼如下:
example@localhost~/test ls -lrt chmod_examples
-rw--w---- 1 example Domain Users 0 Jul 15 11:42 chmod_examples
example@localhost~/test chmod o+w chmod_examples
example@localhost~/test ls -lrt chmod_examples
-rw--w--w- 1 example Domain Users 0 Jul 15 11:42 chmod_examples
chmod命令實例3:對所有的類型成員(文件擁有者+所在組+其他)擁有的權限進行修改
在上一個unix的chmod命令例子中我們知 道如何逐個為 文件擁有者、所在組及其他類型成員改變權限,但是有的時候會需要對所有的類型成員的權限進行修改而不僅僅只是逐個修改其中之一。如果你使用文本格式,那麼我們食用‘a’來表示所有,‘u’用來表示文件擁有者。
復制代碼代碼如下:
example@localhost~/test ls -lrt linux_command.txt
-rw--w--w- 1 example Domain Users 0 Jul 15 11:42 linux_command.txt
example@localhost~/test chmod a+x linux_command.txt
example@localhost~/test ls -lrt linux_command.txt
-rwx-wx-wx 1 example Domain Users 0 Jul 15 11:42 linux_command.txt*
chmod命令實例4:使用chmod命令的數字格式來改變權限
在unix中,chmod命令不僅僅允許使用可讀性高的文本格式來改變權限,同時也允許使用數字格式中的八進制格式來表示權限組合。例如777中的第一個數字指文件擁有者、第二個是對用戶所在組,而第三個則是對其他類型用戶。現在如果你將第一個數字轉換成二進制格式,那麼它被寫成如111,其中第一個數字表示讀屬性,第二個數字表示寫屬性第三個則表示可執行的權限。
復制代碼代碼如下:
example@localhost~/test ls -lrt unix_command.txt
-rw--w--w- 1 example Domain Users 0 Jul 15 11:42 unix_command.txt
example@localhost~/test chmod 777 unix_command.txt
example@localhost~/test ls -lrt unix_command.txt
-rwxrwxrwx 1 example Domain Users 0 Jul 15 11:42 unix_command.txt*
chmod命令實例5:使用chmod命令來移除文件的權限
在這個unix中使用chmod的例子中,我們將知道如何從文件中移除各種權限。你可以很容易使用chmod命令的數字格式或者文本格式從文件中移除讀、寫或者執行的權限。下面的例子展示了使用 -x 的文本格式來移除可執行權限。
復制代碼代碼如下:
example@localhost~/test ls -lrt linux_command.txt
-rwx-wx-wx 1 example Domain Users 0 Jul 15 11:42 linux_command.txt*
example@localhost~/test chmod a-x linux_command.txt
example@localhost~/test ls -lrt linux_command.txt
-rw--w--w- 1 example Domain Users 0 Jul 15 11:42 linux_command.txt
chmod命令實例6:使用chmod命令來改變目錄權限以及遞歸改變子目錄的權限
這是chmod命令中最常用的例子,它為我們提供了可以改變任何目錄以及該目錄包含所有內容包括子目錄和文件的權限。在unix中的chmod命令可以通過使用 -R 這個命令參數遞歸的改變任何目錄的權限,下面的例子中將會展示chmod例子。
復制代碼代碼如下:
example@localhost~/test ls -lrt
total 8.0K
-rwxrwxrwx 1 example Domain Users 0 Jul 15 11:42 unix_command.txt*
drwxr-xr-x+ 1 example Domain Users 0 Jul 15 14:33 stocks/
example@localhost~/test chmod -R 777 stocks/
example@localhost~/test ls -lrt
total 8.0K
-rwxrwxrwx 1 example Domain Users 0 Jul 15 11:42 unix_command.txt*
drwxrwxrwx+ 1 example Domain Users 0 Jul 15 14:33 stocks/
example@localhost~/test ls -lrt stocks
total 0
-rwxrwxrwx 1 example Domain Users 0 Jul 15 14:33 online_stock_exchanges.txt*
chmod命令實例7:如何為所用類型用戶從文件中移除讀寫權限
到目前為止我們已經知道了為文件和目錄增加讀、寫及執行的權限,接著我們將學習相反的內容也就是移除讀、寫和執行權限。使用文本格式會非常簡單,因為我們只需要使用 - 來代替 +。就像 + 被用來表示增加權限一樣,- 被用來移除權限。
復制代碼代碼如下:
example@localhost~/test ls -lrt stock_trading_systems
-rwxrwxrwx 1 example Domain Users 0 Jul 15 11:42 stock_trading_systems*
example@localhost~/test chmod a-wx stock_trading_systems
example@localhost~/test ls -lrt stock_trading_systems
-r--r--r-- 1 example Domain Users 0 Jul 15 11:42 stock_trading_systems
chmod命令實例8:只對目錄設置可執行權限卻不改變其包含文件的權限
很多時候我們僅僅是想為目錄或者子目錄提供可執行的權限使得其可以被搜尋到,卻不想改變在這些目錄中的文件的權限。在我指導這個命令之前,我一般都是找到所有的目錄然後改變它們的權限。但是在unix中我們可以使用chmod有一個更好地方法來做到。你可以使用‘X’(大寫的X)參數來僅僅改變文件目錄的的權限而不影響到文件。讓我們從下面的例子中來看看這種用法。
復制代碼代碼如下:
example@localhost~/test ls -lrt
total 8.0K
-r--r--r-- 1 example Domain Users 0 Jul 15 11:42 stock_trading_systems
drw-rw-rw-+ 1 example Domain Users 0 Jul 15 14:33 stocks/
example@localhost~/test chmod a+X *
example@localhost~/test ls -lrt
total 8.0K
-r--r--r-- 1 example Domain Users 0 Jul 15 11:42 stock_trading_systems
drwxrwxrwx+ 1 example Domain Users 0 Jul 15 14:33 stocks/
記住使用大寫的X,如果你使用的是小寫將會影響到所有的文件和目錄
chmod命令實例9:在unix和linux中 使用chmod命令改變一個文件或目錄的多重權限
你可以在一條命令中使用 user+groups 或者 groups+other 組合來改變文件以及目錄的權限。在下面的例子中,chmod命令做了與為擁有者和組成員提供可執行的權限相同的事情。
復制代碼代碼如下:
example@localhost~/test ls -lrt
total 8.0K
-r--r--r-- 1 example Domain Users 0 Jul 15 11:42 stock_trading_systems
drwxrwxrwx+ 1 example Domain Users 0 Jul 15 14:33 stocks/
example@localhost~/test chmod u+x,g+x stock_trading_systems
example@localhost~/test ls -lrt stock_trading_systems
-r-xr-xr-- 1 example Domain Users 0 Jul 15 11:42 stock_trading_systems*
chmod命令實例10:如何在unix中將一個文件的權限拷貝到另一個文件
這是unix中chmod命令的一個非常有趣的例子,它可以將一個文件的權限並且賦予給另一個。通過下面的例子你可以很容易的參考源文件權限同時拷貝這個文件所有的權限賦予給目標文件:
復制代碼代碼如下:
example@localhost~/test ls -lrt future_trading
-rwxrwxrwx 1 example Domain Users 0 Jul 15 15:30 future_trading*
example@localhost~/test ls -lrt stock_trading_systems
-r--r--r-- 1 example Domain Users 0 Jul 15 11:42 stock_trading_systems
example@localhost~/test chmod --reference=stock_trading_systems future_trading
example@localhost~/test ls -lrt future_trading
-r--r--r-- 1 example Domain Users 0 Jul 15 15:30 future_trading