Linux文件屏蔽字

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 <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环境 */
}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值