《UNIX環境進階編程》筆記--chmod函數和fchmod函數

來源:互聯網
上載者:User

這2個函數都是用來改變現有檔案的存取權限的。函數的定義如下:

#include<sys/stat.h>int chmod(const char* pathname, mode_t mode); //通過檔案名稱對指定的檔案進行操作int fchmod(int filedes, mode_t mode); //通過檔案描述符對以開啟的檔案進行操作//如果成功返回0,失敗返回-1.
為了改變現有檔案的許可權位,進程的有效使用者ID必須等於檔案的所有者ID,或者進程具有超級使用者權限。

參數mode是由中所示常量的按位或運算構成的。


中,有9個是檔案存取權限,另外加了6項,他們是設定使用者ID和設定組ID(S_ISUID和S_ISGID),粘住位(S_ISVTX),

三個組合常量(S_IRWXU,S_IRWXG,S_IRWXO)。


實踐:

#include <stdio.h>#include <sys/stat.h>int main(void){        if(chmod("a",S_IRWXU | S_IRWXO | S_ISUID | S_ISVTX)<0){                perror("chmod");                return -1;        }        return 0;}

運行結果:

yan@yan-vm:~/apue$ ll a
-rw-rw-r-- 1 yan yan 0 Jun 12 13:53 a
yan@yan-vm:~/apue$ ./a.out
yan@yan-vm:~/apue$ ll a
-rws---rwt 1 yan yan 0 Jun 12 13:53 a*


如果要在原來的檔案屬性上加或者減屬性可以先使用stat函數擷取檔案的mode_t,然後再進行與和或操作:

#include <stdio.h>#include <sys/stat.h>int main(void){        struct stat statbuf;        if(stat("a", &statbuf) < 0){                perror("stat");                return -1;        }        if(chmod("a",(statbuf.st_mode & ~S_IRUSR)|S_IWGRP)<0){ //去除檔案a的使用者讀,增加組寫                perror("chmod");                return -1;        }        return 0;}
運行結果:

yan@yan-vm:~/apue$ ll a
-rws---rwt 1 yan yan 0 Jun 12 13:53 a*
yan@yan-vm:~/apue$ ./a.out
yan@yan-vm:~/apue$ ll a
--ws-w-rwt 1 yan yan 0 Jun 12 13:53 a*

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.