Linux Access函數實例應用詳解
由于Linux Access函數只作權限的核查,并不理會文件形態或文件內容,因此,如果一目錄表示為“可寫入”,表示可以在該目錄中建立新文件等操作,而非意味此目錄可以被當做文件處理。例如,你會發現DOS的文件都具有“可執行”權限,但用execve執行時則會失敗。
Linux Access函數(判斷是否具有存取文件的權限)
相關函數
stat,open,chmod,chown,setuid,setgid
表頭文件
#include<unistd.h>
定義函數
int access;
Linux Access函數說明
access會檢查是否可以讀/寫某一已存在的文件。參數mode有幾種情況組合, R_OK,W_OK,X_OK 和F_OK。R_OK,W_OK與X_OK用來檢查文件是否具有讀取、寫入和執行的權限。F_OK則是用來判斷該文件是否存在。由于access只作權限的核查,并不理會文件形態或文件內容,因此,如果一目錄表示為“可寫入”,表示可以在該目錄中建立新文件等操作,而非意味此目錄可以被當做文件處理。例如,你會發現DOS的文件都具有“可執行”權限,但用execve執行時則會失敗。
Linux Access函數返回值
若所有欲查核的權限都通過了檢查則返回0值,表示成功,只要有一權限被禁止則返回-1。
錯誤代碼
EACCESS 參數pathname 所指定的文件不符合所要求測試的權限。
EROFS 欲測試寫入權限的文件存在于只讀文件系統內。
EFAULT 參數pathname指針超出可存取內存空間。
EINVAL 參數mode 不正確。
ENAMETOOLONG 參數pathname太長。
ENOTDIR 參數pathname為一目錄。
ENOMEM 核心內存不足
ELOOP 參數pathname有過多符號連接問題。
EIO I/O 存取錯誤。
Linux Access函數附加說明
使用access作用戶認證方面的判斷要特別小心,例如在access后再做open的空文件可能會造成系統安全上的問題。
范例
/ 判斷是否允許讀取/etc/passwd /
#include<unistd.h>
int main
執行
/etc/passwd can be read
【編輯推薦】