C語言chmod()函數:修改文件權限
頭文件:
#include <sys/types.h> #include <sys/stat.h>
定義函數:
int chmod(const char * path, mode_t mode);
函數說明:chmod()會依參數mode 權限來更改參數path 指定文件的權限。
參數 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 存取錯誤
范例
/* 將/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>
定義函數:
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 存取錯誤。
范例
#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);}
新聞熱點
疑難解答
圖片精選