linux提供了一套相当安全的文件管理方式,它包括文件的权限、属性、ACL还有SELINUX
1、权限
在说文件权限之前,我们得知道它们是什么?
先在终端中输入ls -l /root,root是系统管理员的HOME目录,它下面有一个目录Desktop和文件root.如下所示:
-rw------- 1 root root 8 9月 28 13:36 root
drwxr-xr-x 2 root root 4096 9月 26 21:42 Desktop
你会发现除了名字外前面还有一堆信息,那这些信息都是些什么意思呢?我先拿目录那行来说明
drwxr-xr-x 2 root root 4096 9月 26 21:42 Desktop
再说权限之前先看root和root这两个参数,他们的意思是该目录属于用户root(第一个root)和用户组root(第二个root),这两个不一定非要相同,可以通过命令修改
修改所属用户:chown haha Desktop 将Desktop的拥有者改成用户haha
修改所属组:chgrp heihei Desktop 将Desktop的群组拥有者改成用户组heihei
然后是文件的三大基本权限:读r、写w、执行x
对于文件的意义:
r:可读取文件的实际内容,如读取文本文件的文字内容等;
w:可以新增、修改该文件的内容,但不能删除该文件;
x:该文件可以被系统执行
对于文件夹的意义
r:可以读取文件夹里列表的权限,比如用ls命令将该目录下的内容列出来
w:可以新建、删除、重命名、移除文件夹下的文件和文件夹
x:进入一个文件夹的权限,如使用cd进入一个文件夹
说完这两个参数和三大权限后,那前面那十个参数就好理解了
drwxr-xr-x 这十个字母可以分成1+3+3+3四个小组。
第1组:代表该文件的类型,这里是d,代表目录
-代表普通文件,d代表目录,l代表链接文件
b代表读取数据以段为单位的设备,如硬盘
c代表读取数据以字符为单位的设备,如键盘、鼠标
第2组:代表文件拥有者对该文件的权限,这里是rwx,意思是root对该Desktop具有读r、写w、执行x的权限
第3组:代表文件所在组对该文件的权限,这里是r-x,意思是用户组root下面其他非root用户对Desktop具有读r、执行x权限,没有写w权限就用-表示
第4组:代表文件拥有者所在组外其他组及成员对该文件的权限,这里也是r-x,意思是其他组的成员对Desktop读、执行权限,没有写w权限
既然时权限,当然可以修改,修改的命令是chmod,有下面三种方法
数值模式:chmod 764 Desktop,修改完权限变成drwxrw-r--
赋值模式:chmod u=rwx,g=rw,o=r Desktop,修改完权限变成drwxrw-r--
增删模式:chmod u+x,g-x,o-x,修改完变成drwxr--r--
2、特殊权限
SUID、SGID、SBIT
先用ls -l命令看一下下面几个文件或目录的信息:
-rwsr-xr-x. 1 root root 25980 2月 22 2012 /usr/bin/passwd
-rwx--s--x. 1 root slocate 35612 8月 24 2010 /usr/bin/locate
drwxrwxrwt. 24 root root 20480 10月 14 17:55 /tmp
会发现在文件拥有者,文件拥有者所在组,其他组的权限x的位置上被s或者t取代了,这是什么?
先来看看他们的作用:
SUID:当用户执行具有x权限的二进制文件时拥有此文件所有者的权限
SGID:当用户执行具有x权限的二进制文件时拥有此文件所在组的权限,另外也可以对目录设置此权限
SBIT:当用户对某个目录具有w和x权限时,在该目录下建立的文件和目录只有该用户和root用户才可以删除
听着很绕,举个例子:
比如普通用户用passwd命令去修改密码,而密码是存在/etc/shadow文件中,而普通用户是无法修改这个文件的,也就无法把新密码保存进来。
但事实的结果是普通用户是可以修改密码,并且保存到/etc/shadow这个文件中的。
它的流程是这样的:
一、先看下/usr/bin/passwd这个文件,也就时命令passwd。
-rwsr-xr-x. 1 root root 25980 2月 22 2012 /usr/bin/passwd
发现这个文件的拥有者是root,并且其他组的权限为r-x,也就说普通用户对其具有r和x的权限
二、既然普通用户对其具有执行权限,因此当普通用户执行这条命令时,由于s这个权限的存在,那么在执行过程中会暂时获取root的权限
三、由于只有root才可以修改/etc/shadow文件,而在此次执行过程中已经得到了root用户的支持,因此密码会顺利得写入到这个文件中
那么,怎样才能增加这种权限呢?
可以参照第1节权限,使用chmod命令修改,命令如下:
SUID 4 SGID 2 SBIT 1
chmod 6777 这就添加了SUID和SGID权限,就是在原有权限的前面加了一个6
另外,还有可能出现rwsrwsrwt大写的情况,变成rwSrwSrwT,出现这种情况是因为用户不具备文件的x权限,而又用上面的命令强加了特殊权限
这就矛盾了,因为这三个权限的基础是用户对其有有x权限,现在连x权限都没有,那有sst这个权限又有什么用呢!
|