红联Linux门户
Linux帮助

实例解析Linux下目录的权限

发布时间:2008-07-19 22:35:27来源:红联作者:lyq617617
说明:如果对umask,权限值,文件的权限r,w,x都不了解的朋友,请先去补一下这方面的知识,这里不做介绍,直接进入正题.
希望通过实例讲解,能让更多的初学者对目录的权限更清晰,更明白!
本实例用到两个帐号:root 和 一般用户(root用户的提示符 "#" 号,一般用户的提示符 "$" 号).下面例子中有些地方就不再明确说明当前是用的哪个帐号操作,看命令提示符就明白了.
首先用root用户运行以下命令:
[/color][color=sienna]# umask 得到root用户的默认权限掩码值为:0022
也就是说如果root用户新建一个目录,目录的权限值为755(即自己对目录有rwx权限,同组用户对目录有rx权限,其它用户对目录有rx权限).
接着运行如下命令:
# cd /home 进入 home 目录,因为其它用户都能直接进入此目录,故在这里做测试
# mkdir test 新建 test 目录作为此次测试的目录
# ls -l 主要查看此目录的权限信息
[color=red]在其后的操作中我们只关注 ls -l 命令输出信息中关于 test 目录(drwxr-xr-x 2 root root 1024 07-19 21:55 test)的第一栏(drwxr-xr-x )的后三位(r-x )(即其它用户对此目录的操作权限).[/color]
1.测试目录的执行权限(x)的含义
我们会发现其它用户对 test 目录具有读和执行的权限.接着
# chmod o-x test 去掉其它用户对 test 目录的执行权限
# ls -l 输出结果:drwxr-xr-- 2 root root 1024 07-19 21:55 test
现在用一般用户操作
[color=sienna]$ cd /home/test 尝试进入 root 用户建立的 /home/test 目录[/color]
[color=black]显示错误信息为:-bash: cd: /home/test: 权限不够;[/color]
[color=black] 接着用 root 用户运行:[/color]
# chmod o+x test 加上其它用户对 test 目录的执行权限
[color=#000000][color=sienna]# ls -l [/color]输出结果:drwxr-xr-x 2 root root 1024 07-19 21:55 test
用一般用户操作:
[/color]
[color=sienna] $ cd /home/test 无错误提示证明已经进入 test 目录
$ ls -l 输出信息:总计 0[/color]
[color=red]结论1:如果要进入一个目录,必须具备该目录的执行权限.[/color]
[color=#ff0000] 2.测试目录的只读权限(r)的含义[/color]
[color=#0000ff][size=3] [color=black]有必要说明,上面的测试完成后, test 目录的权限[color=green](用 ls -l 查看:drwxr-xr-x 2 root root 1024 07-19 21:55 test),我们看到其它用户对此目录具备只读权限.[/color][/color][/size][/color]
[color=#000000] 用 root 用户运行以下命令:[/color]
# chmod o-r test 去掉其它用户对 test 目录的只读权限(r)
# ls -l 输出信息:drwxr-x--x 2 root root 1024 07-19 21:55 test
然后用一般用户

$ cd /home/test 进入到 test 目录
$ ls -l 想查看 test 目录下的内容
错误提示信息:ls: .: 权限不够.但是在上例中有($ ls -l 输出信息:总计 0).
[color=red]结论2:[/color][color=red]如果用户对目录 test 不具备只读权限(具备执行权限),当它进入 test 目录后,是无法查看 test 目录下的内容的(如运行命令 ls -l 等).[/color]
[size=5][color=blue]3.测试目录的可写权限(w)的含义[/color][/size]
有必要说明,上面的测试完成后, test 目录的权限[color=green](用 ls -l 查看:drwxr-x--x 2 root root 1024 07-19 21:55 test),我们看到其它用户对此目录不具备可写权限.[/color]
用 root 用户运行:
# cd /home 进入到 home 目录
# chmod o+r,o+w test 为其它用户添加只读,可写权限
# ls -l 输出信息:drwxr-xrwx 2 root root 1024 07-19 21:55 test
可以看出其它用户对 test 目录具备所有权限(读,写,执行).

# cd /home/test 进入到 test 目录
# touch rootfile 建立一个名为 rootfile 空的档案
# ls -l 输出信息:-rw-r--r-- 1 root root 0 07-19 22:49 rootfile

可以看到其它用户对 root 用户建立的文件 rootfile 只具备读的权限.
用一般用户运行:
$ cd /home/test
$ vi rootfile

编辑 rootfile,你会发现在 vi 编辑器的底部提示:W10: 警告: 正在修改一个只读文件,不管它,我们随便输入几行文字,然后
!wq 强行保存退出.
$ ls -l 输出信息:-rw-r--r-- 1 liufeng liufeng 5 07-19 23:09 rootfile
你会发现:虽然其它用户对 rootfile 文件只具备读权限,但其它用户还是能强行改写 rootfile 文件,保存后 rootfile 文件的用户和属组都发生改变了,这是为什么呢?会不会是因为 rootfile文件在 /home/test 目录下,而其它用户对 test 目录具备写权限呢?带着问题我们继续测试.
root 用户:
# cd /home 进入 home 目录
# chmod o-w test 去掉其它用户对 test 目录的可写权限
# ls -l 输出信息:drwxr-xr-x 2 root root 1024 07-19 23:09 test
# cd test
# rm rootfile rm:是否删除 一般文件 “rootfile”? y 删除rootfile
# touch rootfile1 [color=green]再次建立空档案,命名为 rootfile1
[/color] # ls -l 输出信息:-rw-r--r-- 1 root root 0 07-19 23:19 rootfile1
接下来,我想不说大家也明白,就是用一般用户去编辑 root 用户刚才新建立的空档案,你会发现,编辑完成后就是用强行保存退出(!wq)都不行,提示说:"rootfile1" E212: 无法打开并写入文件.只能是强行退出(!q)了.接着:
$ mkdir file1 错误信息:mkdir: 无法创建目录 “file1”: 权限不够
$ touch file2 错误信息:touch: 无法触碰 “file2”: 权限不够
你会发现,此时建立目录和文件都不允许[color=green](不妨试一下,在其它用户对 test 目录具备写权限时是可以在 test 目录下建立目录和文件的)
.[/color]
[color=red]结论:如果用户对目录具备写权限,就能够创建\删除\修改该目录中的所有文件和子目录,即使是其它人的文件或子目录.
[/color]
这里没有讲到 SUID,SGID和t等特殊权限,以后有时间会发上来.最后做一个简单的总结:
1. 对目录的只读权限也不允许进入那个目录,要进入目录,必须拥有目录的执行权限x.
2. 如果设置了可执行权限,只要存在下面的条件,就能够访问目录中的文件:
1> 知道它们的名称
2> 能读文件
[color=blue]3. 要列出目录中的内容(如 ls 等)并且进入一个目录,需要拥有目录的读和执行两个权限
4. 如果用户对目录具备写权限,就能够创建\删除\修改该目录中的所有文件和子目录,即使是其它人的文件或子目录.
[/color]

:0)1

[ 本帖最后由 lyq617617 于 2008-7-20 22:38 编辑 ]
文章评论

共有 3 条评论

  1. lyq617617 于 2008-07-20 22:41:15发表:

    写这篇帖子花了不少时间的,但是觉得是值得的.
    对有些知识的了解总是很模糊,自己用心过一遍记忆会很深刻,顺便贴出来,希望对其他人也有帮助!
    :0)1

  2. lzllinux 于 2008-07-20 08:44:38发表:

    学习!!!!!!!!!!

  3. Distance 于 2008-07-19 23:57:50发表:

    学一下东西