umask文件权限屏蔽字

(1)当用户创建一个文件时,需要为新的文件指定一个权限字,在实际应用中,系统有时不希望用户设置所有的权限

(2)例如:有些服务器程序允许客户端在服务器上创建一些文件,但是处于安全考虑,服务器系统希望该文件不应该是可执行文件

(3)于是这些文件的可执行位都应该被设置为0.但遗憾的是并非所有的用户都会遵守这个约定,有些恶意的程序可能会专门设置文件的执行位

(4)出于上面的情况考虑,就出现了umask权限屏蔽字,可以屏蔽一些不希望用户干预的权限位。也就是说即使用户设置了该文件的相关位,系统也会忽略用户对该位的指定的值,而将其设置为0


#include <sys/stat.h>
mode_t umask(mode_t cmask); //返回值是以前的屏蔽字,可以将其保存,操作后恢复
1)umask的参数cmask表示一个新的屏蔽字,其类型为mode_t类型
2)mode_t类型也是一个位向量,对应9位权限标志位
3)哪一位的屏蔽位为1,说明用户在创建文件时所指定的权限标志无效,新文件不具有该权限,为0则相反,是否具有该权限取决于用户提供的权限字
4)所以要创建屏蔽字为0,表示新文件所有权限位都由用户指定,系统不干预


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值