chmod(函数名称)

Linux中较为常见的命令(command)函数名称:chmod函数原型:intchmod(constchar*filename,intpmode);所属库:io.h函数功能:改变文件的读写许可设置,如果改变成功返回0,否则返回-1

chmod(函数名称)

Linux命令

命令描述

变更文件或目录的权限。在UNIX系统家族里,文件或目录权限的控制分别以读取,写入,执行3种一般权限来区分,另有3种特殊权限可供运用,再搭配拥有者与所属群组管理权限范围。您可以使用chmod指令去变更文件与目录的权限,设置方式采用文字或数字代号皆可。符号连接的权限无法变更,如果您对符号连接修改权限,其改变会作用在被连接的原始文件。权限范围的表示法如下:

u:User,即文件或目录的拥有者。

例子:u+x为user获得执行权限

g:Group,即文件或目录的所属群组。

o:Other,除了文件或目录拥有者或所属群组之外,其他用户皆属于这个范围。

a:All,即全部的用户,包含拥有者,所属群组以及其他用户。

有关权限代号的部分,列表于下:

r:读取权限,数字代号为"4"。

w:写入权限,数字代号为"2"。

x:执行或切换权限,数字代号为"1"。

-:不具任何权限,数字代号为"0"。

s:当文件被执行时,根据who参数指定的用户类型设置文件的setuid或者setgid权限。

语法

chmod[-cfRv][–help][–version][<权限范围>+/-/=<权限设置…>][文件或目录…]

chmod[-cfRv][–help][–version][数字代号][文件或目录…]

chmod[-cfRv][–help][–reference=<参考文件或目录>][–version][文件或目录…]

选项说明

-c或–changes效果类似"-v"参数,但仅回报更改的部分。

-f或–quiet或–silent不显示错误信息。

-R或–recursive递归处理,将指定目录下的所有文件及子目录一并处理。

-v或–verbose显示指令执行过程。

–help在线帮助。

–reference=<参考文件或目录>把指定文件或目录的权限全部设成和参考文件或目录的权限相同

–version显示版本信息。

<权限范围>+<权限设置>开启权限范围的文件或目录的该项权限设置。

<权限范围>-<权限设置>关闭权限范围的文件或目录的该项权限设置。

<权限范围>=<权限设置>指定权限范围的文件或目录的该项权限设置。

范例

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

chmodugo+rfile1.txt

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

chmoda+rfile1.txt

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

chmodug+w,o-wfile1.txtfile2.txt

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

chmodu+xex1

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

chmod-Ra+r*

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

chmodu+ssqlplus

此外,chmod也可以用数字来表示权限如chmod777file

语法为:chmodabcfile

其中a,b,c各为一个数字,分别表示User、Group、及Other的权限。

r=4,w=2,x=1

若要rwx属性则4+2+1=7;

若要rw-属性则4+2=6;

若要r-x属性则4+1=5。

范例二:

chmoda=rwxfile

chmod777file

效果相同

chmodug=rwx,o=xfile

chmod771file

效果相同

若用chmod4755filename可使此程式具有root的权限

范例三:

如果在cd/media/amasun/java/develop/array之后执行

chmod777./

是将本目录(即/media/amasun/java/develop/array)设为任何人可读,写,执行

如果是管理员也就是常说的ROOT用户的话,基本上有可以查看所有文件的权力.

范例四:

chmodu+xfilename

这里chmod改变的的是“filename”的mode,u代表的是user,+代表的是添加,x代表的是可执行

该文章由作者:【蒋小明】发布,本站仅提供存储、如有版权、错误、违法等相关信息请联系,本站会在1个工作日内进行整改,谢谢!

发表回复

登录后才能评论