chmod命令用来改变文件或者目录的权限

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无法新建文件

 

相关文章