chmod命令用來改變文件或者目錄的許可權,只有文件的屬主和超級用戶才能夠執行這個命令 格式: chmod [option] [mode] [file] >常用參數選項 -R : 遞歸修改目錄以及子目錄下麵的所有文件許可權 >模式有兩種格式,一種採用字母方式的表達式,另外一種是數字 1,首先需要瞭解文件 ...
chmod命令用來改變文件或者目錄的許可權,只有文件的屬主和超級用戶才能夠執行這個命令
格式:
chmod [option] [mode] [file]
>常用參數選項 -R : 遞歸修改目錄以及子目錄下麵的所有文件許可權
>模式有兩種格式,一種採用字母方式的表達式,另外一種是數字
1,首先需要瞭解文件的許可權和屬主和屬組。
ghostwu@dev:~/linux/chown$ ls -l total 4 -rw-rw-r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
-rw-rw-r-- 這個就是文件的許可權, 除去第一位, 一共有9位組成
第一位表示文件類型,- 表示這個是一個常規文件
後面9位,每3位一組. 第一個3位rw-表示屬主許可權, 第二個3位rw-表示屬組許可權,第三個3位r--表示其他用戶許可權,
後面有2個ghostwu, 第一個ghostwu, 表示屬主, 也就是這個test.txt文件的擁有者是ghostwu
第二個ghostwu,表示屬組,也就是這個test.txt文件可以被ghostwu這個組的用戶 rw-( 可讀,可寫)
2,修改文件許可權
>增加許可權( + )
ghostwu@dev:~/linux/chown$ chmod a+x test.txt ghostwu@dev:~/linux/chown$ ls test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxrwxr-x 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
a等價於 用戶(u)+組(g)+其他組( o )。 a+x 就是給用戶,組,其他組都加上x(可執行)許可權
>去掉許可權( - )
ghostwu@dev:~/linux/chown$ chmod a-x test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -rw-rw-r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
>設置許可權( = )
ghostwu@dev:~/linux/chown$ chmod a=r-- test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -r--r--r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
>給屬主加上w( 可寫 ), x( 可執行 ) 許可權
ghostwu@dev:~/linux/chown$ chmod u+wx test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxr--r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
>給組加上wx許可權
ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxr--r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ chmod g+wx test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxrwxr-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
>給其他組加上wx許可權
ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxrwxr-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ chmod o+wx test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxrwxrwx 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
>r( 4 ), w( 2 ), x( 1 )
ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxrwxrwx 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ chmod 444 test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -r--r--r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
ghostwu@dev:~/linux/chown$ ls -l total 4 -r--r--r-- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ chmod 755 test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxr-xr-x 1 ghostwu ghostwu 20 5月 9 22:55 test.txt
許可權詳解:
一、普通文件
可讀r: 讀取/閱讀文件內容的許可權
ghostwu@dev:~/linux/chown$ ls -l total 4 -rwxr-xr-x 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ chmod 000 test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 ---------- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ cat test.txt cat: test.txt: Permission denied ghostwu@dev:~/linux/chown$ chmod 400 test.txt ghostwu@dev:~/linux/chown$ ls -l total 4 -r-------- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ cat test.txt this is a test file
可寫(w):具有新增,修改文件內容的許可權
ghostwu@dev:~/linux/chown$ ls -l test.txt -r-------- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ echo 'aaa' > test.txt bash: test.txt: Permission denied ghostwu@dev:~/linux/chown$ chmod u+w test.txt ghostwu@dev:~/linux/chown$ ls -l test.txt -rw------- 1 ghostwu ghostwu 20 5月 9 22:55 test.txt ghostwu@dev:~/linux/chown$ echo 'ghostwu' >> 'test.txt' ghostwu@dev:~/linux/chown$ cat test.txt this is a test file ghostwu
可執行( x )
1,文件本身要用x許可權
ghostwu@dev:~/linux/chown$ ls -l test.txt -rw------- 1 ghostwu ghostwu 28 5月 9 23:20 test.txt ghostwu@dev:~/linux/chown$ ./test.txt bash: ./test.txt: Permission denied ghostwu@dev:~/linux/chown$ chmod u+x test.txt ghostwu@dev:~/linux/chown$ ls -l test.txt -rwx------ 1 ghostwu ghostwu 28 5月 9 23:20 test.txt ghostwu@dev:~/linux/chown$ ./test.txt ./test.txt: line 1: this: command not found ./test.txt: line 2: ghostwu: command not found
ghostwu@dev:~/linux/chown$ echo 'ls /' > test.sh ghostwu@dev:~/linux/chown$ ls -l total 8 -rw-rw-r-- 1 ghostwu ghostwu 5 5月 9 23:22 test.sh -rwx------ 1 ghostwu ghostwu 28 5月 9 23:20 test.txt ghostwu@dev:~/linux/chown$ ./test.sh bash: ./test.sh: Permission denied ghostwu@dev:~/linux/chown$ chmod u+x test.sh ghostwu@dev:~/linux/chown$ ls -l test.sh -rwxrw-r-- 1 ghostwu ghostwu 5 5月 9 23:22 test.sh ghostwu@dev:~/linux/chown$ ./test.sh bin dev initrd.img lost+found opt run srv usr boot etc lib media proc sbin sys var cdrom home lib64 mnt root snap tmp vmlinuz
普通用戶需要擁有r許可權, 然後x許可權 才能執行
ghostwu@dev:~/linux/chown$ ls -l test.sh -rwxrw-r-- 1 ghostwu ghostwu 5 5月 9 23:22 test.sh ghostwu@dev:~/linux/chown$ chmod u-r test.sh ghostwu@dev:~/linux/chown$ ls -l test. ls: cannot access 'test.': No such file or directory ghostwu@dev:~/linux/chown$ ls -l test.sh --wxrw-r-- 1 ghostwu ghostwu 5 5月 9 23:22 test.sh ghostwu@dev:~/linux/chown$ ./test.sh bash: ./test.sh: Permission denied
root用戶不需要r許可權,只要有x許可權就能執行
root@dev:/home/ghostwu/linux/chown# ls -l test.sh --wxrw-r-- 1 ghostwu ghostwu 5 5月 9 23:22 test.sh root@dev:/home/ghostwu/linux/chown# ./test.sh bin dev initrd.img lost+found opt run srv usr boot etc lib media proc sbin sys var cdrom home lib64 mnt root snap tmp vmlinuz root@dev:/home/ghostwu/linux/chown# chmod a-x test.sh root@dev:/home/ghostwu/linux/chown# ls -l test.sh --w-rw-r-- 1 ghostwu ghostwu 5 5月 9 23:22 test.sh root@dev:/home/ghostwu/linux/chown# ./test.sh -su: ./test.sh: Permission denied root@dev:/home/ghostwu/linux/chown# chmod o+x test.sh root@dev:/home/ghostwu/linux/chown# ls -l test.sh --w-rw-r-x 1 ghostwu ghostwu 5 5月 9 23:22 test.sh root@dev:/home/ghostwu/linux/chown# ./test.sh bin dev initrd.img lost+found opt run srv usr boot etc lib media proc sbin sys var cdrom home lib64 mnt root snap tmp vmlinuz
二、目錄許可權
可讀r: 具有瀏覽目錄下麵文件及其子目錄的許可權,即:ls 目錄
ghostwu@dev:~/linux$ ls -l total 12 drwxrwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ ls chown test.sh test.txt ghostwu@dev:~/linux$ chmod u-r chown ghostwu@dev:~/linux$ ls -l chown ls: cannot open directory 'chown': Permission denied ghostwu@dev:~/linux$ ls -l total 12 d-wxrwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown
沒有x許可權,不能cd切換到目錄
ghostwu@dev:~/linux$ ls -l total 12 d-wxrwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ cd chown ghostwu@dev:~/linux/chown$ ls ls: cannot open directory '.': Permission denied
ghostwu@dev:~/linux/chown$ cd .. ghostwu@dev:~/linux$ ls -l total 12 d-wxrwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ chmod u-x chown ghostwu@dev:~/linux$ ls -l total 12 d-w-rwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ cd chown -su: cd: chown: Permission denied
w: 具有增加,刪除或者修改目錄內文件名的許可權,需要x許可權配合
ghostwu@dev:~/linux$ ls -l total 12 d-w-rwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ cd chown -su: cd: chown: Permission denied ghostwu@dev:~/linux$ chmod u+x chown ghostwu@dev:~/linux$ ls -l total 12 d-wxrwxr-x 2 ghostwu ghostwu 4096 5月 9 23:22 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ cd chown ghostwu@dev:~/linux/chown$ ls -l ls: cannot open directory '.': Permission denied ghostwu@dev:~/linux/chown$ touch a.txt ghostwu@dev:~/linux/chown$ ls -l . ls: cannot open directory '.': Permission denied ghostwu@dev:~/linux/chown$ ls -l a.txt -rw-rw-r-- 1 ghostwu ghostwu 0 5月 9 23:34 a.txt
如果父目錄沒有w許可權,是不能刪除目錄下麵的文件的
ghostwu@dev:~/linux/chown$ ls -l a.txt -rw-rw-r-- 1 ghostwu ghostwu 0 5月 9 23:34 a.txt ghostwu@dev:~/linux/chown$ rm -f a.txt ghostwu@dev:~/linux/chown$ ls -l a.txt ls: cannot access 'a.txt': No such file or directory ghostwu@dev:~/linux/chown$ touch a.txt ghostwu@dev:~/linux/chown$ cd .. ghostwu@dev:~/linux$ ls -l total 12 d-wxrwxr-x 2 ghostwu ghostwu 4096 5月 9 23:35 chown drwxr-xrwx 6 root root 4096 5月 7 22:38 cp drwxrwxr-x 3 ghostwu ghostwu 4096 5月 8 23:01 rename ghostwu@dev:~/linux$ chmod u-w chown ghostwu@dev:~/linux$ ls -l chown/a.txt -rw-rw-r-- 1 ghostwu ghostwu 0 5月 9 23:35 chown/a.txt ghostwu@dev:~/linux$ rm -f chown/a.txt rm: cannot remove 'chown/a.txt': Permission denied
x: 具有進入目錄的許可權:如cd dir
>沒有r無法列表
>沒有w無法新建文件