open和creat函数用于创建新文件,link函数用于创建一个硬链接,symlink用于创建一个符号链接,mkdir用于创建一个新目录。这些函数都可以看作是创建新文件的函数。这些函数的原型汇总如下:
int open (const char *pathname, int oflag, ...);
int creat (const char *pathname, mode_t mode);
int link(const char *existingpath, const char *newpath);
int symlink(const char *actualpath, const char *sympath);
int mkdir(const char *pathname, mode_t mode);
显然,这些函数的参数中都没有用户所有者ID和所有组ID。任何文件产生的同时必须具有所有者及相关权限,否则系统就很不安全。没有传递用户参数,又要有用户信息,那么必然是采取某种默认机制来设定用户信息。
1、新建文件(包括新目录)的用户ID:
所有unix系统都将新建文件的用户ID设置为进程的有效用户ID。
2、新建文件(包括新目录)的组ID:
不同的unix系统或者文件系统对新建文件的组ID设置方案有所不同。
FreedBSG5.2.1和Mac OS X 10.3系统:
总是使用目录的组ID作为新文件的组ID。
POSIX.1标准允许选择:
(1)新文件的组ID可以是进程的有效组ID;
(2)新文件的组ID可以是它所在目录的组ID。
Linux ext2和ext3文件系统:
(1)新文件所在目录的S_ISGID位为1,则新文件的组ID设置为目录的组ID;
(2)新文件所在目录的S_ISGID位为0,则新文件的组ID设置为进程的有效组ID。