本篇博文內容摘自《UNIX環境高級編程》(第二版),僅作個人學習記錄所用。關於本書可參考:http://www.apuebook.com/。
這兩個函數使我們可以更改現有文件的訪問權限:
#include <sys/stat.h> int chmod( const char *pathname, mode_t mode ); int fchmod( int filedes, mode_t mode ); 兩個函數返回值:若成功則返回0,若出錯則返回-1
chmod函數在指定的文件上進行操作,而fchmod函數則對已打開的文件進行操作。
為了改變一個文件的權限位,進程的有效用戶ID必須等於文件的所有者ID,或者該進程必須具有超級用戶權限。
參數mode是表4-8中所示常量的某種按位或運算構成的。
表4-8 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  |  
           其他讀、寫和執行  其他讀 其他寫 其他執行  |  
          
程序清單4-4 chmod函數實例
[root@localhost apue]# cat prog4-4.c #include "apue.h" int main(void) { struct stat statbuf; /* turn on set-group-ID and turn off group-execute */ if(stat("foo", &statbuf) < 0) err_sys("stat error for foo"); if(chmod("foo", (statbuf.st_mode & ~S_IXGRP) | S_ISGID) < 0) err_sys("chmod error for foo"); /* set absolute mode to "rw-r--r--" */ if(chmod("bar", S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH) < 0) err_sys("chmod error for bar"); exit(0); }
