详细对比C语言中的chmod()函数和fchmod()函数
C语言chmod()函数:修改文件权限
头文件:
#include<sys/types.h>#include<sys/stat.h>
定义函数:
intchmod(constchar*path,mode_tmode);
函数说明:chmod()会依参数mode权限来更改参数path指定文件的权限。
参数mode有下列数种组合:
1、S_ISUID04000文件的(setuser-idonexecution)位
2、S_ISGID02000文件的(setgroup-idonexecution)位
3、S_ISVTX01000文件的sticky位
4、S_IRUSR(S_IREAD)00400文件所有者具可读取权限
5、S_IWUSR(S_IWRITE)00200文件所有者具可写入权限
6、S_IXUSR(S_IEXEC)00100文件所有者具可执行权限
7、S_IRGRP00040用户组具可读取权限
8、S_IWGRP00020用户组具可写入权限
9、S_IXGRP00010用户组具可执行权限
10、S_IROTH00004其他用户具可读取权限
11、S_IWOTH00002其他用户具可写入权限
12、S_IXOTH00001其他用户具可执行权限
注:只有该文件的所有者或有效用户识别码为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、EIOI/O存取错误
范例
/*将/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()函数:修改文件的权限
头文件:
#include<sys/types.h>#include<sys/stat.h>
定义函数:
intfchmod(intfildes,mode_tmode);
函数说明:fchmod()会依参数mode权限来更改参数fildes所指文件的权限。参数fildes为已打开文件的文件描述词。参数mode请参考chmod()。
返回值:权限改变成功则返回0,失败返回-1,错误原因存于errno.
错误代码:
1、EBADF参数fildes为无效的文件描述词。
2、EPERM进程的有效用户识别码与欲修改权限的文件所有者不同,而且也不具root权限。
3、EROFS欲写入权限的文件存在于只读文件系统内。
4、EIOI/O存取错误。
范例
#include<sys/stat.h> #include<fcntl.h> main() { intfd; fd=open("/etc/passwd",O_RDONLY); fchmod(fd,S_IRUSR|S_IWUSR|S_IRGRP|S_IROTH); close(fd); }