歡迎您光臨本站 註冊首頁

Linux:Access函數實例應用詳解

←手機掃碼閱讀     火星人 @ 2014-03-12 , reply:0
  

  由於Linux Access函數只作許可權的核查,並不理會文件形態或文件內容,因此,如果一目錄表示為“可寫入”,表示可以在該目錄中建立新文件等操作,而非意味此目錄可以被當做文件處理。例如,你會發現DOS的文件都具有“可執行”許可權,但用execve執行時則會失敗。

  Linux Access函數(判斷是否具有存取文件的許可權)

  相關函數stat,open,chmod,chown,setuid,setgid表頭文件#include定義函數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 int main

  執行/etc/passwd can be read



[火星人 ] Linux:Access函數實例應用詳解已經有374次圍觀

http://coctec.com/docs/program/show-post-71482.html