linux C之access函數

linux C之access函數

access():判斷是否具備存取文件的權限
linux

相關函數
    stat,open,chmod,chown,setuid,setgid
表頭文件
    #include<unistd.h>
定義函數
    int access(const char * pathname, int mode);
函數說明
    access()會檢查是否能夠讀/寫某一已存在的文件。參數mode有幾種狀況組合, R_OK,W_OK,X_OK 和F_OK。R_OK,W_OK與X_OK用來檢查文件是否具備讀取、寫入和執行的權限。F_OK則是用來判斷該文件是否存在。因爲access()只做權限的核查,並不理會文件形態或文件內容,所以,若是一目錄表示爲「可寫入」,表示能夠在該目錄中創建新文件等操做,而非意味此目錄能夠被當作文件處理。例如,你會發現DOS的文件都具備「可執行」權限,但用execve()執行時則會失敗。
返回值
    若全部欲查覈的權限都經過了檢查則返回0值,表示成功,只要有一權限被禁止則返回-1
錯誤代碼
    EACCESS 參數pathname 所指定的文件不符合所要求測試的權限。
    EROFS 欲測試寫入權限的文件存在於只讀文件系統內。
    EFAULT 參數pathname指針超出可存取內存空間。
    EINVAL 參數mode 不正確。
    ENAMETOOLONG 參數pathname太長。
    ENOTDIR 參數pathname爲一目錄。
    ENOMEM 核心內存不足    
    ELOOP 參數pathname有過多符號鏈接問題。
    EIO I/O 存取錯誤。
附加說明
    使用access()做用戶認證方面的判斷要特別當心,例如在access()後再作open()的空文件可能會形成系統安全上的問題。安全

範例

#include<unistd.h>
int main()
{
    if (access(「/etc/passwd」,R_OK) = =0)
        printf(「/etc/passwd can be read\n」);
}
執行
/etc/passwd can be read 函數

相關文章
相關標籤/搜索