umask 设置文件权限掩码

本文介绍了Linux系统中文件权限掩码umask的工作原理和作用。当创建文件或目录时,初始权限可能受到umask影响而不同于预期。umask是一个设置用户不希望文件或目录具有的权限,它的值会从设定的权限中移除。例如,普通用户默认umask是0002,意味着组和其他用户无法拥有写权限。通过`umask`命令或umask函数可以更改权限掩码。文章详细解析了权限掩码如何与文件权限结合计算最终权限,并提供了设置权限掩码的方法。

我们在创建文件或者目录时,看到的权限往往和我们设置的不一样,原因就在于创建文件时要受到 umask的影响。


目录

一、实际情景介绍

二、文件权限掩码

1、什么是权限掩码?

2、权限掩码的作用过程

3、设置权限掩码的两种方式

(1) umask 命令设置权限掩码

(2) umask 函数设置权限掩码


一、实际情景介绍

使用open系统函数以写的方式打开一个文件(文件不存在则直接创建),此时OS就会帮我们创建出一个文件,初始赋予的权限是 0666(创建者、组、其他都具有读写权限)

// O_WRONLY: 以只写的形式打开文件
// O_CREAT: 如果文件不存在,则直接创建
// 0666: 设置文件的初始权限,0666由八进制转二进制就是110 110 110,
//       即创建者、组、其他都具有读写权限
open("./log", O_WRONLY | O_CREAT, 0666);

但是实际创建出来的文件权限如下,实际文件的权限是 0644,这是因为受到了文件权限掩码的影响。(详见下面 “权限掩码的作用过程” )

二、文件权限掩码

1、什么是权限掩码?

文件权限掩码是 OS不希望某些成员具备的权限,即便设置了也不会生效。普通用户的权限掩码是 0002,超级用户

### Linuxumask 的取反掩码概念及其作用 #### 什么是 umask? `umask` 是一种用于定义新创建文件或目录默认权限的机制。它通过从最大可能权限中减去掩码值,从而决定实际分配给文件或目录的初始权限[^1]。 #### 如何计算 umask 值? 当用户运行 `umask` 命令时,返回的是一个八进制数值,该值表示需要屏蔽掉的最大权限位。例如: ```bash [userA@linux01 ~]$ umask 0027 ``` 这里的 `0027` 表示掩码值为 `0027`(八进制形式),其中每一位分别对应于特殊权限、属主权限、同组权限以及其他用户的权限[^2]。 #### 文件和目录的最大权限 - **对于文件**:其理论上的最大权限是 `666`(读+写权限)。 - **对于目录**:其理论上的最大权限是 `777`(读+写+执行权限)。 这是因为文件通常不会被赋予可执行权限,而目录则需要具备执行权限以便访问内部内容[^3]。 #### 计算最终权限的方法 要得到新创建对象的实际权限,需按照如下方式操作: 1. 将最大权限与 `umask` 值按位相减; 2. 结果即为目标对象的默认权限。 具体例子说明如下: 假设当前系统的 `umask` 设置为 `0027`,那么: - 对于文件,默认权限将是 `(666 - 027)` 即 `640`,意味着只有属主具有读写权,其他人都无任何权利; - 对于目录,则变为 `(777 - 027)` 或者说 `750` ,这表明除开自己外仅允许所属群组成员进入浏览但不可修改删除等动作发生[^4]。 #### 使用场景举例 如果希望调整项目协作环境下的共享程度可以通过更改此参数实现更灵活控制比如设置成较低数值如`0002`让团队成员之间更容易互相查看彼此的工作成果而不至于完全开放给所有人随意篡改破坏数据安全边界等等情况都需要合理规划好这些细节方面的考量因素才行哦! ```python # Python 示例展示如何模拟计算过程 def calculate_permissions(max_perm, umask_value): """Calculate final permissions based on max permission and umask.""" return int(str(int(oct(max_perm), 8) ^ int(umask_value)), 8) file_max_permission = 0o666 directory_max_permission = 0o777 current_umask = '0027' calculated_file_perms = calculate_permissions(file_max_permission, current_umask) print(f"Calculated File Permissions: {oct(calculated_file_perms)}") calculated_dir_perms = calculate_permissions(directory_max_permission, current_umask) print(f"Calculated Directory Permissions: {oct(calculated_dir_perms)}") ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值