麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 系統 > 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>
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: va免费视频 | 嗯哈~不行好大h双性 | 激情在线免费观看 | 国产精品久久久久久久久久东京 | 久久综合综合久久 | 精品xxxx户外露出视频 | 欧洲精品久久 | h久久| 久久精品亚洲欧美日韩精品中文字幕 | 一本一道久久久a久久久精品91 | 在线成人免费网站 | 性生活视频一级 | 欧美性生活久久久 | 亚洲一区二区不卡视频 | 人人做人人看 | 在线观看一二三 | 亚洲天堂岛国片 | 久久久国产一区二区三区 | 91久久久久久亚洲精品禁果 | 国产亚洲精品久久久久婷婷瑜伽 | 日韩在线激情 | 免费一级毛片在线播放视频 | 成人一区二区三区四区 | 久久久久久久久浪潮精品 | 久草成人在线 | 欧洲成人在线视频 | 亚洲一区免费观看 | 久久久中精品2020中文 | 国产99久久久国产精品下药 | 综合国产在线 | 欧美黄色一级生活片 | 欧美国产91 | 亚洲欧美aⅴ | 性欧美xxxx免费岛国不卡电影 | 91精品国产免费久久 | 欧美大屁股精品毛片视频 | 高清国产午夜精品久久久久久 | v11av在线视频成人 | 亚洲精品一区二区三区在线看 | 色播av在线| 国产一区二区三区在线免费 |