详细对比C语言中的chmod()函数和fchmod()函数

C语言chmod()函数:修改文件权限
头文件:

1

#include <sys/types.h>  #include <sys/stat.h>

定义函数:

1

int chmod(const char * path, mode_t mode);

函数说明:chmod()会依参数mode 权限来更改参数path 指定文件的权限。

下表 chmod函数的mode常量,取自<sys/stat.h>

mode说明
S_ISUID
S_ISGID
S_ISVTX
执行时设置用户ID
执行时设置组ID
保存正文(粘住位)
S_IRWXU
     S_IRUSR
     S_IWUSR
     S_IXUSR
用户(所有者)读、写和执行
用户(所有者)读
用户(所有者)写
用户(所有者)执行
S_IRWXG
     S_IRGRP
     S_IWGRP
     S_IXGRP
组读、写和执行
组读
组写
组执行
S_IRWXO
     S_IROTH
     S_IWOTH
     S_IXOTH
其他读、写和执行
其他读
其他写
其他执行

参数 mode 有下列数种组合:
1、S_ISUID 04000 文件的 (set user-id on execution)位
2、S_ISGID 02000 文件的 (set group-id on execution)位
3、S_ISVTX 01000 文件的sticky 位
4、S_IRUSR (S_IREAD) 00400 文件所有者具可读取权限
5、S_IWUSR (S_IWRITE)00200 文件所有者具可写入权限
6、S_IXUSR (S_IEXEC) 00100 文件所有者具可执行权限
7、S_IRGRP 00040 用户组具可读取权限
8、S_IWGRP 00020 用户组具可写入权限
9、S_IXGRP 00010 用户组具可执行权限
10、S_IROTH 00004 其他用户具可读取权限
11、S_IWOTH 00002 其他用户具可写入权限
12、S_IXOTH 00001 其他用户具可执行权限

注:只有该文件的所有者或有效用户识别码为0,才可以修改该文件权限。

基于系统安全,如果欲将数据写入一执行文件,而该执行文件具有S_ISUID 或S_ISGID 权限,则这两个位会被清除。如果一目录具有S_ISUID 位权限,表示在此目录下只有该文件的所有者或root 可以删除该文件。

返回值:权限改变成功返回0, 失败返回-1, 错误原因存于errno.

错误代码:
1、EPERM 进程的有效用户识别码与欲修改权限的文件拥有者不同, 而且也不具root 权限.
2、EACCESS 参数path 所指定的文件无法存取.
3、EROFS 欲写入权限的文件存在于只读文件系统内.
4、EFAULT 参数path 指针超出可存取内存空间.
5、EINVAL 参数mode 不正确
6、ENAMETOOLONG 参数path 太长
7、ENOENT 指定的文件不存在
8、ENOTDIR 参数path 路径并非一目录
9、ENOMEM 核心内存不足
10、ELOOP 参数path 有过多符号连接问题.
11、EIO I/O 存取错误

范例

1

2

3

4

5

6

7

/* 将/etc/passwd 文件权限设成S_IRUSR|S_IWUSR|S_IRGRP|S_IROTH */

#include <sys/types.h>

#include <sys/stat.h>

main()

{

  chmod("/etc/passwd", S_IRUSR|S_IWUSR|S_IRGRP|S_IROTH);

}

C语言fchmod()函数:修改文件的权限
头文件:

1

#include <sys/types.h>  #include <sys/stat.h>

定义函数:

1

int fchmod(int fildes, mode_t mode);

函数说明:fchmod()会依参数mode 权限来更改参数fildes 所指文件的权限。参数fildes 为已打开文件的文件描述词。参数mode 请参考chmod ()。

返回值:权限改变成功则返回0, 失败返回-1, 错误原因存于errno.

错误代码:
1、EBADF 参数fildes 为无效的文件描述词。
2、EPERM 进程的有效用户识别码与欲修改权限的文件所有者不同, 而且也不具root 权限。
3、EROFS 欲写入权限的文件存在于只读文件系统内。
4、EIO I/O 存取错误。

范例

1

2

3

4

5

6

7

8

9

#include <sys/stat.h>

#include <fcntl.h>

main()

{

  int fd;

  fd = open("/etc/passwd", O_RDONLY);

  fchmod(fd, S_IRUSR|S_IWUSR|S_IRGRP|S_IROTH);

  close(fd);

}

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值