日期:2014-05-16  浏览次数:20642 次

redhat Linux系统 chmod授权命令

功能说明:变更文件或目录的权限。

语  法:chmod [-cfRv][--help][--version][<权限范围>+/-/=<权限设置...>][文件或目录...] 或 chmod [-cfRv][--help][--version][数字代号][文件或目录...] 或 chmod [-cfRv][--help][--reference=<参考文件或目录>][--version][文件或目录...] 

补充说明:在UNIX系统家族里,文件或目录权限的控制分别以读取,写入,执行3种一般权限来区分,另有3种特殊权限可供运用,再搭配拥有者与所属群组管理权限范围。您可以使用chmod指令去变更文件与目录的权限,设置方式采用文字或数字代号皆可。符号连接的权限无法变更,如果您对符号连接修改权限,其改变会作用在被连接的原始文件。权限范围的表示法如下: 
 u:User,即文件或目录的拥有者。 
 g:Group,即文件或目录的所属群组。 
 o:Other,除了文件或目录拥有者或所属群组之外,其他用户皆属于这个范围。 
 a:All,即全部的用户,包含拥有者,所属群组以及其他用户。 
 
 有关权限代号的部分,列表于下(使用2进制进行计算,分别是111, 011, 001, 000): 
 r:读取权限,数字代号为"4"。 
 w:写入权限,数字代号为"2"。 
 x:执行或切换权限,数字代号为"1"。 
 -:不具任何权限,数字代号为"0"。 
 s:特殊?b>功能说明:变更文件或目录的权限。
 
参  数:
 -c或--changes  效果类似"-v"参数,但仅回报更改的部分。 
 -f或--quiet或--silent  不显示错误信息。 
 -R或--recursive  递归处理,将指定目录下的所有文件及子目录一并处理。 
 -v或--verbose  显示指令执行过程。 
 --help  在线帮助。 
 --reference=<参考文件或目录>  把指定文件或目录的权限全部设成和参考文件或目录的权限相同 
 --version  显示版本信息。 
 <权限范围>+<权限设置>  开启权限范围的文件或目录的该项权限设置。 
 <权限范围>-<权限设置>  关闭权限范围的文件或目录的该项权限设置。 
 <权限范围>=<权限设置>  指定权限范围的文件或目录的该项权限设置。

 

符号模式:

使用符号模式可以设置多个项目:who(用户类型),operator(操作符)和permission(权限),每个项目的设置可以用逗号隔开。 命令chmod将修改who指定的用户类型对文件的访问权限,用户类型由一个或者多个字母在who的位置来说明,如who的符号模式表所示:

who 用户类型 说明
u user 文件所有者
g group 文件所有者所在组
o others 所有其他用户
a all 所用用户, 相当于 ugo

operator的符号模式表:

Operator 说明
+ 为指定的用户类型增加权限
- 去除指定用户类型的权限
= 设置指定用户权限的设置,即将用户类型的所有权限重新设置

permission的符号模式表:

模式 名字 说明
r 设置为可读权限
w 设置为可写权限
x 执行权限 设置为可执行权限
X 特殊执行权限 只有当文件为目录文件,或者其他类型的用户有可执行权限时,才将文件权限设置可执行
s setuid/gid 当文件被执行时,根据who参数指定的用户类型设置文件的setuid或者setgid权限
t 粘贴位 设置粘贴位,只有超级用户可以设置该位,只有文件所有者u可以使用该位

范例

范例一 :将档案 file1.txt 设为所有人皆可读取 :

  chmod ugo+r file1.txt

  将档案 file1.txt 设为所有人皆可读取 :

  chmod a+r file1.txt

  将档案 file1.txt 与 file2.txt 设为该档案拥有者,与其所属同一个群体者可写入,但其他以外的人则不可写入 :

  chmod ug+w,o-w file1.txt file2.txt

  将 ex1.设定为只有该档案拥有者可以执行 :

  chmod u+x ex1

  将目前目录下的所有档案与子目录皆设为任何人可读取 :

  chmod -R a+r *

  当其他用户执行oracle的sqlplus这个程序时,他的身份因这个程序暂时变成oracle

  chmod u+s sqlplus