4.1.获取各种类型文件的信息的函数(eg:文件类型,文件访问权等)(注:文件信息包含在stat结构中,stat结构可以参见课本P75)
#include <sys/stat.h>
(1)int stat ( 绝对路径,struct stat *restrict buf )
(2)int lstat (绝对路径,struct stat *restrict buf )
#以上两个中的buf是指向stat结构类型的指针,两个的唯一区别是:lstat返回该符号链接(软链接)的有关信息,而不是由该符号链接指向文件的信息
(3)int fstat (文描述符,struct stat *buf )
(4)int fstatat (当前目录的文件描述符dirdf,绝对路径,struct stat *restrict buf,int flag )
#以下转载自http://http://blog.csdn.net/alex_my/article/details/39184461
文件类型信息在stat结构中的st-mode成员中,但是我们无法知道,只能借助宏的返回结果来判断文件类型。
具体用法为:宏(buf.st-mode)
如果返回为非0则为该宏所代表的文件信息,否则不是
4.3设置用户ID和用户组ID
待续......
4.4文件(普通文件,目录,字符特别文件等)访问权限
(1)9种权限分为三种:用户,组和其他,每组里面包括读(4),写(2),执行(1)
注意点:
- 目录的读权限:获得该目录下的所有文件名
- 目录的执行权限:通过该目录,继续往下寻找,也称为“搜索该目录“,
#例如:文件的绝对路径为:/home/someone/4-4.c
#对于目录home来说,如果仅仅想知道home该层下有几个文件,那么就只需要对home这个目录具有读权限
#但是如果想进入到4-4.c这个文件,那么就需要对home具有执行权限
- 目录的写权限:改变目录下的文件数量,例如删除和新建文件,这个两个操作需要对这个目录具有执行和写的权限
- 由于文件的读写执行权限比较简单,这里不再赘述。
(2)进程每次打开,创建和删除一个文件时,内核会对其进行文件访问测试,判断其所具有的操作权限。判断顺序如下
- 判断进程有效用户ID是否为root,如果是则允许访问
- 判断进程有效用户ID是否为文件所有者ID,如果是则赋予文件所有者的所有权限
- 判断进程有效用户组ID或附属组ID是否为文件的组ID,如果是则赋予文件的组的权限
- 最后赋予进程其他用户的权限
4.5新文件和目录的所有权
待续......