您的位置:首页 > 编程语言

UNIX环境高级编程——第四章

2015-09-29 23:19 204 查看
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

   -1: 如果pathname是相对路径,则是相对于dirfd的路径,不是相对于当前进程工作空间。

   -2: 如果pathname是相对路径,且dirfd为AT_FDCWD,则是相对于当前进程工作空间。

   -3: 如果pathname是绝对路径,则dirfd会被忽略。

   第四个参数flags可以取以下值:

   AT_EMPTY_PATH: pathname可以为空,此时获得的是dirfd所指向文件的信息。

   AT_NO_AUTOMOUNT: 和挂载点有关,允许手机挂载点的属性。

   AT_SYMLINK_NOFOLLOW: 如果path指向一个符号链接,则返回该链接信息。默认情况下,fstatat返回的就是链接信息。
4.2文件类型

文件类型信息在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新文件和目录的所有权

待续......
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息