在Linux中,文件有三种权限--可读,可写,可执行。目录也有三种权限--可读,可写,可执行。但是实际上他们有着不同的意义。
对于文件:
可读 :表示可以读取文件里的数据;
可写 :表示可以改变和删除文件; 可执行:表示可以执行该程序。
对于目录:
可读:表示,你可以列出目录中有什么文件;
可写:表示可以在目录中删除和增加文件;
可执行:表示可以列出目录下文件的信息。
参考:http://forums.fedoraforum.org/archive/index.php/t-45213.html
在我们使用ls -l命令时,我们常常可以在每一行的最前列看到类似于: “-rwxr-xr-x 3 ret etc 6743 Nov 9 09:45 atob”的输出,我来解释一下,它有十个字符组成,第一个字符表示文件的性质,“-”表示,这是一般的文件,接着的三个字符“rwx/"表示,文件所有者的权限,这里表示可读“r/",可写“w/",可执行“x/"。接下来的三个字符表示群组成员的权限,这里“r-x/"表示他们可读,和可执行,但是不可写,接下来的三个字符,表示其他人的权限,这里表示可读,和可写。/"ret/"表示文件的所有者,/"etc/"表示了文件所属的群组。当然,如果这行的第一个字符不是“-”,而是“d/"的话,就表示这是一个目录。
当然,一般情况下,虽然,文件或者目录产生时,文件和目录都会有一种缺省的权限模式,不过 我们有些时候需要自己来改变,各种权限,我们要使用的命令有三个。
其中 chown 用来改变文件的所有者(注意,只有root才能执行chown命令) chgrp 用来改变文件所属的群组 chmod 用来改变文件的权限(最为重要)
1、chown的格式是“chown 文件拥有者 文件名”。比如,你想把文件test的所有者改为lib,就这样使用 “chown lib test”
2、chgrp的格式是“chgrp 文件的群组 文件名”。 比如,你想把文件test的群组改为etc,就这样使用 “chgrp etc test”
3、chmod的格式最为复杂,但也最有用,chmod有两种语法:
第一种:符号模式 “chmod 权限对象 运算符 权限 文件名” 其中 “权限对象“ 使用“u,g,o/"三个字符来表示,分别表示/"用户,群组,其他人“, 权限使用“r,w,x/"三个字符表示,“可读,可写,可执行”。运算符使用“+,-”表示增加和去掉。比如这样使用: chmod +x test(给test加入可执行权限) chmod u+x test(只给自己设置可执行权限) chmod ug+rwx test(给自己和群组设置可读,可写,可执行三种权限) chmod -x test(给test去掉可执行权限)
第二种:绝对模式 “chmod 绝对符号 文件名” 这种模式下,用户、群组及其他人分别拥有的三种权限都用数字来表示,具体的是: 用户 群组 其他人 可读 可写 可执行 可读 可写 可执行 可读 可写 可执行 400 200 100 40 20 10 4 2 1 使用那个数字表示开启那个所有者的那种权限,如使用 chmod 400 test,表示开启自己的可读权限,入使用“chmod 777 test”表示开启所有用户的所有权限,你应该想到了,对于每个所有者,权限的数字表示,是加起来的。777中的700=400+200+100 70=40+20+10 ,7= 4+2+1,哈哈懂了吧:)