分享

chmod

 心不留意外尘 2016-05-05
http://blog.csdn.net/searchsun/article/details/3284932
2008
 说到chmod,就必然要提到linux对文件的分类,linux中的文件和目录其实都是当一个文件来对待的,只是有不同的标示,在一个目录下,运行 ls -l,可以看到
-rwx-rw--r-- username file1.txt
linux对文件档案的权限分成三组 ,分别是用户、组、其他。一般来说,一个用户都属于某个群组,群组和用户之外的就是其他。并且权限也分三类,分别是读r、写w、执行x.可见上面的file1.txt对于用户username来说有读,写,执行的权限,而对于同属于一个组的成员,只有读,写的权限,而这个组之外的成员,只有可读权限。

既然有权限的分类,肯定也可以进行权限的更改,这就用到chmod
chmod [-cfvR] [--help] [--version] mode file
[-cfvR]不常用分别标示
-c : 若该档案权限确实已经更改,才显示其更改动作
-f : 若该档案权限无法被更改也不要显示错误讯息
-v : 显示权限变更的详细资料
-R : 对目前目录下的所有档案与子目录进行相同的权限变更(即以递回的方式逐个变更)
mode 是按照一定格式的为[ugoa][+-=][rwxX]
其中
u:user
g:group
o:others
a:all
+ 表示增加,-表示否定,=表示唯一赋予
r 可读,w可写,x可执行,X 只有当前文件是个子目录,或者已经被定义为可执行

范例:
1.将 file1.txt增加所有人都可读的权限
chmod ugo+r file1.txt 或者
chmod a+r file1.txt
2.file1.txt对当前用户和用户的组可写,其他人不可写
chmod ug+w,o-w file1.txt
3.file1.txt and file2.txt
对当前用户和用户的组可写,其他人不可写
chmod ug+w,o-w file1.txt file2.txt
4.将当前目录下所有的子目录都设定为可读
chmod -R a+r *


数字表示权限
对于r w x,也可以用八进制数来表示(其实也是二进制),分别为4,2,1,并且对于三组权限,也是按照顺序来写
例如
rwx-rw--r-- 按照数字为764,第一个7是对于u来讲的,6是对于g,4 是对others
但是这种情况只对应于=的例子,不适用于增加和减少权限的形式
例如
chmod ug=rw,o=r file1.txt
可改为chmod 664 file1.txt

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多