国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Unix > 正文

《Unix環境高級編程》讀書筆記 第4章-文件和目錄

2024-06-28 13:24:58
字體:
來源:轉載
供稿:網友
《Unix環境高級編程》讀書筆記 第4章-文件和目錄1. stat結構的基本形式:
  1. struct stat {
  2. mode_t st_mode; /* file type & mode (permissions), suid, sgid */
  3. ino_t st_ino; /* i-node number (serial number) */
  4. dev_t st_dev; /* device number (file system) */
  5. dev_t st_rdev; /* device number for special files */
  6. nlink_t st_nlink; /* number of links */
  7. uid_t st_uid; /* user ID of owner */
  8. gid_t st_gid; /* group ID of owner */
  9. off_t st_size; /* size in bytes, for regular files */
  10. struct timespec st_atim; /* time of last access */
  11. struct timespec st_mtim; /* time of last modification */
  12. struct timespec st_ctim; /* time of last file status change */
  13. blksize_t st_blksize; /* best I/O block size */
  14. blkcnt_t st_blocks; /* number of disk blocks allocated , 512B */
  15. };
  16. struct timespec {
  17. time_t tv_sec;
  18. long tv_nsec;
  19. }
2. 函數stat、fstat、fstatat、lstat
  • 函數名首位的“f”常常代表“該函數是通過文件描述符fd(而不是路徑名)對文件進行操作的”
  1. #include <sys/stat.h>
  2. int stat(const char *restrict pathname, struct stat *restrict buf );
  3. int fstat(int fd, struct stat *buf );
  4. int lstat(const char *restrict pathname, struct stat *restrict buf ); // 返回該符號鏈接本身的有關信息
  5. int fstatat(int fd, const char *restrict pathname, struct stat *restrict buf, int flag);
  6. All four return: 0 if OK, −1 on error
3. 文件類型
  • 普通文件 -
  • 目錄文件 d
  • 塊特殊文件 b
  • 字符特殊文件 c
  • FIFO p
  • 套接字 s
  • 符號鏈接 l

  • 文件類型宏:參數為stat結構中的st_mode成員(文件模式字)

  • ipC類型宏:參數為stat結構的指針

4. 設置用戶ID(SUID) 和 設置組ID(SGID)
  • 每個進程關聯的用戶ID和組ID,包括實際用戶ID、有效用戶ID、保存的設置用戶ID。
  • 實際用戶ID指的是執行該程序的用戶的ID。注意區別于文件的所有者

  • 每個文件有一個所有者和組所有者,由stat結構中的st_uid, st_gid指定。

  • 當執行一個程序文件時,進程的有效用戶ID通常就是實際用戶ID。但是,可以在文件模式字(st_mode)中設置一個標志,使其“當執行該程序文件時,將進程的有效用戶ID設置為文件所有者的ID(st_uid)”。進程的有效組ID類似,在文件模式字st_mode中的這兩位標志被稱為SUID和SGID。可使用常量S_ISUID和S_ISGID測試。
  • 應用:passwd命令
5. 文件訪問權限
  • 所有文件類型都有訪問權限

  • 進程每次打開、創建或刪除一個文件時,內核就進行文件訪問權限測試,這種測試可能涉及文件的所有者(st_uid和st_gid)、進程的有效ID(有效用戶ID和有效組ID)、進程的附屬組ID。兩個所有者ID是文件的性質,而兩個有效ID和附屬組ID則是進程的性質。

  • 內核進行的測試具體如下:
  1. 若進程的有效用戶ID是0(超級用戶),則運行訪問
  2. 若進程的有效用戶ID等于文件的所有者ID(即進程擁有此文件),那么如果所有者適當的訪問權限位被設置,則運行訪問;否則拒絕訪問。適當的訪問權限位指的是:若進程為讀而打開該文件,則用戶讀位應為1;若進程為寫而打開該文件,則用戶寫位應為1;若進程將執行該文件,則用戶執行位應為1。
  3. 若進程的有效組ID或進程的附屬組ID之一等于文件的組ID,那么如果組適當的訪問權限位被設置,則允許訪問;否則拒絕訪問。
  4. 若其他用戶適當的訪問權限位被設置,則允許訪問;否則拒絕訪問。按順序執行這4步。一旦前面的被拒絕了,即使后面的組、其他用戶擁有相應權限也白搭。
6. 新文件和新目錄的所有權
  • 新文件的用戶ID設置為進程的有效用戶ID
  • 新目錄的組ID有兩種選擇:1. 設置為進程的有效組ID;2. 設置為它的父目錄的組ID。

    linux下如果新目錄的父目錄的SUID被設置,則選擇2

7. 函數access 和 faccessat

當open函數打開一個文件時,內核以進程的有效用戶ID和有效組ID為基礎執行其訪問權限測試。有時,進程希望以進程的實際用戶ID和實際組ID為基礎來執行其訪問權限測試。這使用以下兩個函數:

  1. #include <unistd.h>
  2. int access(const char *pathname, int mode);
  3. int faccessat(int fd, const char *pathname, int mode, int flag);
  4. Both return: 0 if OK, −1 on error

測試文件是否存在,mode為F_OK;測試讀/寫/執行權限,mode為R_OK、W_OK、X_OK的按位與

8. 函數umask
  • 在進程創建一個新文件或新目錄時,一定會使用文件模式創建屏蔽字。在文件模式創建屏蔽字中為1的位,在文件mode中的相應位一定被關閉。
  • 常用的幾種umask值是002、022、027
  • 命令umask [-S]
  1. #include <sys/stat.h>
  2. mode_t umask(mode_t cmask);
  3. Returns: PRevious file mode creation mask

9. 函數chmod、fchmod和fchmodat
  1. #include <sys/stat.h>
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 镇坪县| 大厂| 临桂县| 瓮安县| 武汉市| 凯里市| 墨江| 体育| 常州市| 饶平县| 深水埗区| 双鸭山市| 深州市| 磴口县| 肥乡县| 民权县| 杭锦后旗| 商丘市| 如皋市| 贵阳市| 安丘市| 墨竹工卡县| 辽阳县| 临夏县| 泰顺县| 德庆县| 贵定县| 东源县| 开封县| 鹤峰县| 佳木斯市| 明水县| 哈尔滨市| 敖汉旗| 永德县| 永定县| 玉林市| 六枝特区| 弥渡县| 怀集县| 原阳县|