邪恶八进制信息安全团队技术讨论组's Archiver

pub!1c 2006-9-8 23:59

[转载]解读Linux文件权限的设置方法

<p>信息来源: rInG04h's blog</p><p>Windows系统其实和Linux系统有相似的地方,Windows系统文件、目录的属性有只读、隐藏,而Linux也一样。<br /><br />  Linux中,每一个文件都具有特定的属性。主要包括文件类型和文件权限两个方面。可以分为5种不同的类型:普通文件、目录文件、链接文件、设备文件和管道文件。<br /><br />  所谓的文件权限,是指对文件的访问权限,包括对文件的读、写、删除、执行。Linux 是一个多用户操作系统,它允许多个用户同时登录和工作。因此 Linux 将一个文件或目录与一个用户或组联系起来。访问控制列表(ACL:Access Control List)为计算机提供更好的访问控制,它的作用是限制包括root用户在内的所有用户对文件、资源或者套接字的访问。下面就来教大家简单的设置方法。<br /><br /><br />步骤1 检查系统核心<br /><br />  首先检查你的Linux系统的核心是否有支持ACL的功能。因为Linux系统并不是每一个版本的核心都有支持ACL的功能,而最简单的方法就是检查系统目前的核心能否支持:<br /><br />  [root@mail /]# cat /boot/config-kernel-version | grep -i ext3<br /><br />  CONFIG_EXT3_FS=m<br /><br />  CONFIG_EXT3_IDEX=y<br /><br />  CONFIG_EXT3_FS_XATTR_SHARING=y<br /><br />  CONFIG_EXT3_FS_XATTR_USER=y<br /><br />  CONFIG_EXT3_FS_XATTR_TRUSTED=y<br /><br />  CONFIG_EXT3_FS_ACL=y<br /><br />  此时如果能看到上面的几项则表示已经编译到核心中,ext3文件系统已支持ACL功能,这些功能在编译核心选项中都可以找到。如果编译时找不到,可以到ACL的官方网站来安装Kernel(acl.bestbits.at/)。<br /><br /><br />步骤2 挂载分区<br /><br />  你可以用下列的方式挂载分区并启用ACL:<br /><br />  #mount -t ext3 -o acl /dev/sda1 /fs1<br /><br />  你也可以直接写在/etc/fstab文件中,这样就可以在开机后支持ACL功能:<br /><br />  #vi /etc/fstab<br /><br />  步骤3 设置ACL权限<br /><br /><br />  ACL常常针对个别用户来进行设置,下面是多个不同的例子:<br /><br />  例如需要创建test1、test2、test3三个用户,可以先用root身份登录系统,然后执行以下命令分别创建三个用户名和密码:<br /><br />  [root@mail root]#adduser test1<br />  [root@mail root]#adduser test2<br />  [root@mail root]#adduser test3<br />  [root@mail root]#passwd test1<br />  [root@mail root]#passwd test2<br />  [root@mail root]#passwd test3<br /><br />然后mount一个ext3文件到目录/fs1:<br />  [root@mail root]#mount -t ext3 -o acl /dev/sda1 /fs1<br /><br />  再将test1 建立的文件设置读写的权限给test2 :<br />  [root@mail root]#chmod -R 777 /fs1<br /><br />  让所有的用户都能增加文件到目录的权限:<br /><br />  先用test1登录系统,执行命令:<br />  [test1@mail test1]# cd /fs1<br />  [test1@mail fs1]# echo "Create by test1" > test1.txt<br />  [test1@mail fs1]# chmod go-r test1.txt<br />  [test1@mail fs1]# ll test1.txt<br />  -rw------- 1 test1 test1 17 Jul 14 22:11 test1.txt<br /><br />  而如下操作则可以让除了test1有读写的权限外其他人没有读写test1.txt的权限(root除外),先用test2 登录系统后执行以下命令:<br />  [test2@mail test2]# cd /fs1<br />  [test2@mail fs1]# cat test1.txt<br />  cat : test1.txt Permission denied<br /><br />  接着用test1登录系统,执行如下命令:<br />  [test1@mail fs1]# setfacl -m u:test2:rw test1.txt<br /><br />  这样就修改权限允许test2 有这个文件的读写权限。再看一下它的文件属性的变化:<br />  [test1@mail fs1]# ll<br />  -rw-rw-r--+ 1 test1 test1 10 Feb 16 13:52 test1.txt<br /><br />  会看到后面多了一个“+”,表示这个文件使用ACL的属性设置,再用命令getfacl来看ACL的文件属性设置:<br />  [test1@mail fs1]# getfacl test1.txt<br />  # file: test1.txt<br />  # owner: test1<br />  # group: test1<br />  user::rw-<br />  user:test2:rw-<br />  group::rw-<br />  mask::rw-<br />  other::r--<br /><br />  可以看到 test2 有权限读写这个文件。<br /><br />  我们再用test2登录系统执行以下命令,看看发生了什么?<br />  [test2@mail test2]# cd /fs1<br />  [test2@mail fs1]# cat test1.txt<br />  Create by test1<br /><br />  原来test2可以读取test1.txt文件了。<br />  [test2@mail fs1]# echo "Modify by test2" >> test1.txt<br />  [test2@mail fs1]# cat test1.txt<br />  Create by test1<br />  Modify by test2<br /><br />  现在test2也可以修改test1.txt文件了。<br /><br />  接着用test3 登录系统:<br />  [test3@mail test3]# cd /fs1<br />  [test3@mail fs1]# cat test1.txt<br />  cat : test1.txt Permission denied<br /><br />  嘿嘿,除了test1、test2外没有其他用户有读写test1.txt的权限(root 除外)。<br /></p>

pub!1c 2006-9-9 00:00

[url]http://www-128.ibm.com/developerworks/cn/linux/l-acl/index.html[/url]

Linux ACL 体验
developerWorks

级别: 初级

高 延斌 ([email]gaoyanb@cn.ibm.com[/email]), 软件工程师,WPLC部门,IBM中国软件开发中心

2006 年 6 月 22 日

在安全管理日益重要的今天,传统的 Unix 文件系统的 UGO 权限管理方式已经无法满足日常系统管理工作的需要。而 ACL 机制逐渐成为主流的权限管理方式。本文主要介绍了在基于 Linux2.6 内核的发行版 Fedora Core 上进行的一些 ACL 基本功能的实验。

ACL 简介

用户权限管理始终是 Unix 系统管理中最重要的环节。大家对 Linux/Unix 的 UGO 权限管理方式一定不陌生,还有最常用的 chmod 命令。为了实现一些比较复杂的权限管理,往往不得不创建很多的组,并加以详细的记录和区分(很多时候就是管理员的噩梦)。可以针对某一个用户对某一文件指定一个权限,恐怕管理员都期待的功能。比如对某一个特定的文件,用户A可以读取,用户B所在的组可以修改,惟独用户B不可以……。于是就有了IEEE POSIX 1003.1e这个ACL的标准。所谓ACL,就是Access Control List,一个文件/目录的访问控制列表,可以针对任意指定的用户/组分配RWX权限。现在主流的商业Unix系统都支持ACL。FreeBSD也提供了对ACL的支持。Linux在这个方面也不会落后,从2.6版内核开始支持ACL。

页: [1]
© 1999-2008 EvilOctal Security Team