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 函數