Linux文件屏蔽字
2015-10-15 16:18
495 查看
Linux环境下使用umask()函数创建一个权限屏蔽字,其函数原型如下:
#include <sys/stat.h>
mode_t umask(mode_t cmask);
umask的参数表示一个新的屏蔽字,其类型为mode_t类型。
mode_t类型也是一个位向量,对应9位权限标志位。哪一位的屏蔽位为1,说明用户在创建文件时所指定的权限标志无效,新文件不具有该权限;如为0则相反,是否具有该权限,取决于用户的权限字。所以,如果创建屏蔽字为0,表示新文件所有的权限完全由用户指定,系统不干预;创建屏蔽字为0x1ff,说明新文件所有的权限位全部被忽略,文件没有任何权限。
umask的返回值是以前的屏蔽字,用户可以保存该屏蔽字,用于操作后对屏蔽字的恢复。
1,检查当前的权限屏蔽字
umask
2,修改
umask XXX
在程序中使用文件屏蔽字umask()函数不会影响shell环境,但是会影响程序所有新文件的权限设置。
#include <sys/stat.h>
mode_t umask(mode_t cmask);
umask的参数表示一个新的屏蔽字,其类型为mode_t类型。
mode_t类型也是一个位向量,对应9位权限标志位。哪一位的屏蔽位为1,说明用户在创建文件时所指定的权限标志无效,新文件不具有该权限;如为0则相反,是否具有该权限,取决于用户的权限字。所以,如果创建屏蔽字为0,表示新文件所有的权限完全由用户指定,系统不干预;创建屏蔽字为0x1ff,说明新文件所有的权限位全部被忽略,文件没有任何权限。
umask的返回值是以前的屏蔽字,用户可以保存该屏蔽字,用于操作后对屏蔽字的恢复。
1,检查当前的权限屏蔽字
umask
2,修改
umask XXX
在程序中使用文件屏蔽字umask()函数不会影响shell环境,但是会影响程序所有新文件的权限设置。
#include <stdio.h> #include <stdlib.h> #include <fcntl.h> #include <sys/stat.h> /* 屏蔽所有者、组用户和其他用户的“可读权限” */ #define MASK S_IRUSR | S_IRGRP | S_IROTH int main(void) { int fd; mode_t mask; mask = umask(MASK); /* 改变权限屏蔽字,并将原来的屏蔽字保存 */ printf("the original mask is %x\n", (unsigned int )mask); /*打印旧的权限屏蔽字 */ /* 使新文件的所有者、组用户和其他用户的权限全部被设置 */ if((fd = open("test.txt", O_CREAT, 0777)) == -1){ perror("fail to create"); exit(1); } close(fd); /* 关闭文件 */ return 0; /* 程序退出,不将umask屏蔽字更改回去,检查其是否影响其所在的 shell环境 */ }
相关文章推荐
- Boa web server 在ARM+Linux上的移植
- 更改Linux系统语言
- Mysql 安装(centOS)
- Linux根目录空间不足
- mysql linux 定时备份
- jdk安装(centos)
- Linux权限管理及用户与用户组
- LINUX经验汇总
- Linux查看CPU和内存使用情况
- Linux free -m 详细说明
- linux安装svn客户端subversion及使用方法
- linux批量重命名
- Java /Jsp 执行操作系统命令 windows/Linux
- linux设置和删除环境变量
- [linux] 使用总结
- 18 个命令&工具帮你定位 Linux 性能问题
- [Linux] - xxx 不在 sudoers 文件中。此事将被报告。
- 有趣的 Linux 命令
- Linux内核工程导论——虚拟化与云
- Linux du命令查看文件夹和文件大小