linux中的umask 函数
2012-11-08 09:39
316 查看
我们创建文件的默认权限是怎么来的?如何改变这个默认权限呢?
umask是什么? 当我们登录系统之后创建一个文件总是有一个默认权限的,那么这个权限是怎么来的呢?这就是umask干的事情。umask设置了用户创建文件的默认权限,它与chmod的效果刚好相反,umask设置的是权限“补码”,而chmod设置的是文件权限码。一般在/etc/profile、$ [HOME]/.bash_profile或$[HOME]/.profile中设置umask值。 如何计算umask值? umask命令允许你设定文件创建时的缺省模式,对应每一类用户(文件属主、同组用户、其他用户)存在一个相应的umask值中的数字。对于文件来说,这一数字的最大值分别是6。系统不允许你在创建一个文本文件时就赋予它执行权限,必须在创建后用chmod命令增加这一权限。目录则允许设置执行权限,这样针对目录来说,umask中各个数字最大可以到7。 该命令的一般形式为:umask nnn 其中nnn为umask置000 - 777。 我们只要记住u m a s k是从权限中“拿走”相应的位即可。 如:umask值为022,则默认目录权限为755,默认文件权限为644。
linux中的 umask 函数主要用于:在创建新文件或目录时 屏蔽掉新文件或目录不应有的访问允许权限。
文件的访问允许权限共有9种,分别是:rwxrwxrwx
它们分别代表:用户读 用户写 用户执行 组读 组写 组执行 其它读 其它写 其它执行
屏蔽的规则如下:
1. 不管屏蔽码是多少,
·新创建的文件默认不具有可执行允可权限。
·新创建的目录默认具有可执行允可权限。
2. 屏蔽码的格式为八进制格式,共三个八进制数。可设置如下 002 或 022 或 ......
3. 其中的每一个八进制数由三位表示,分别是 读 写 执行
4 2 1
例如 002 用二进制表示为: 0 0 0 -- 0 0 0 -- 0 1 0
4 2 1 4 2 1 4 2 1
4. 产生的文件为 umask 值求反后的允可权限,即
对于文件: ~002 = 664(新创建文件所应具有的访问权限)
对于目录: ~002 = 775(新创建目录所应具有的访问权限)
umask是什么? 当我们登录系统之后创建一个文件总是有一个默认权限的,那么这个权限是怎么来的呢?这就是umask干的事情。umask设置了用户创建文件的默认权限,它与chmod的效果刚好相反,umask设置的是权限“补码”,而chmod设置的是文件权限码。一般在/etc/profile、$ [HOME]/.bash_profile或$[HOME]/.profile中设置umask值。 如何计算umask值? umask命令允许你设定文件创建时的缺省模式,对应每一类用户(文件属主、同组用户、其他用户)存在一个相应的umask值中的数字。对于文件来说,这一数字的最大值分别是6。系统不允许你在创建一个文本文件时就赋予它执行权限,必须在创建后用chmod命令增加这一权限。目录则允许设置执行权限,这样针对目录来说,umask中各个数字最大可以到7。 该命令的一般形式为:umask nnn 其中nnn为umask置000 - 777。 我们只要记住u m a s k是从权限中“拿走”相应的位即可。 如:umask值为022,则默认目录权限为755,默认文件权限为644。
linux中的 umask 函数主要用于:在创建新文件或目录时 屏蔽掉新文件或目录不应有的访问允许权限。
文件的访问允许权限共有9种,分别是:rwxrwxrwx
它们分别代表:用户读 用户写 用户执行 组读 组写 组执行 其它读 其它写 其它执行
屏蔽的规则如下:
1. 不管屏蔽码是多少,
·新创建的文件默认不具有可执行允可权限。
·新创建的目录默认具有可执行允可权限。
2. 屏蔽码的格式为八进制格式,共三个八进制数。可设置如下 002 或 022 或 ......
3. 其中的每一个八进制数由三位表示,分别是 读 写 执行
4 2 1
例如 002 用二进制表示为: 0 0 0 -- 0 0 0 -- 0 1 0
4 2 1 4 2 1 4 2 1
4. 产生的文件为 umask 值求反后的允可权限,即
对于文件: ~002 = 664(新创建文件所应具有的访问权限)
对于目录: ~002 = 775(新创建目录所应具有的访问权限)
相关文章推荐
- 【linux】open函数创建新文件及umask函数使用
- linux之umask函数解析
- linux下的umask( )函数、setsid( )函数
- linux下的umask()函数
- linux 权限掩码函数 umask 介绍
- 关闭 linux下的umask( )函数、setsid( )函数
- linux中umask命令/函数的用法简介
- [Linux文件属性]使用umask函数指定新建文件权限
- linux之umask函数解析
- linux的umask函数详解
- linux下的umask( )函数、setsid( )函数
- Linux服务器开发之:chmod()函数,chmod命令,以及文件屏蔽umask命令,程序修改umask,详细介绍+案例演示
- linux下的umask( )函数、setsid( )函数
- linux 权限掩码函数 umask 介绍
- Linux笔记——shell补充:参数传递&函数等
- Uboot-1.1.2 do_bootm_linux函数源码分析
- linux 系统函数之 (dirname, basename)【转】
- Linux网络编程之connect函数分析
- linux下底层函数实现MAC、IP地址以及网关地址
- Linux时间函数详解(转)