Linux——(关于权限常见的3个问题)

修改文件或目录的拥有者和所属组

1.1 chown指令

功能:修改文件的拥有者格式:chown 【参数】用户名 文件名实例:

[root@iZbp19b5lvg8xtpf1tzrenZ test]# lltotal 0-rwxr-x--- 1 root root 0 Apr 26 11:59 test.txt[root@iZbp19b5lvg8xtpf1tzrenZ test]# chown yui test.txt[root@iZbp19b5lvg8xtpf1tzrenZ test]# lltotal 0-rwxr-x--- 1 yui root 0 Apr 26 11:59 test.txt

可以看到,我成功地将拥有者从root更改为yui。请注意:无法将拥有者更改为不存在的用户。

[root@iZbp19b5lvg8xtpf1tzrenZ test]# chown hehe test.txtchown: invalid user: ‘hehe’[root@iZbp19b5lvg8xtpf1tzrenZ test]# lltotal 0-rwxr-x--- 1 yui root 0 Apr 26 11:59 test.txt

1.2 chgrp指令

功能:修改文件的所属组格式:chgrp 【参数】用户名 文件名

常见的权限三个问题

2.1 对应一个目录,如果要进入,需要什么权限?

为了回答这个问题,我们可以使用控制变量法。首先,我们需要切换到普通用户。

[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ whoamiyui[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ chmod 375 newdr[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ lltotal 8d-wxrwxr-x 2 yui yui 4096 Apr 25 19:56 newdr-rw-rw-r-- 1 yui yui    5 Apr 25 19:57 test.txt[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ cd newdr[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ cd ..[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ chmod 575 newdr[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ lltotal 8dr-xrwxr-x 2 yui yui 4096 Apr 25 19:56 newdr-rw-rw-r-- 1 yui yui    5 Apr 25 19:57 test.txt[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ cd newdr[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ cd ..[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ chmod 675 newdr[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ lltotal 8drw-rwxr-x 2 yui yui 4096 Apr 25 19:56 newdr-rw-rw-r-- 1 yui yui    5 Apr 25 19:57 test.txt[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ cd newdrbash: cd: newdr: Permission denied

通过控制变量的方法,我们发现进入目录所需的权限是x,即执行权限。

观察r与w的作用:

[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ chmod 377 newdr[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ cd newdr[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ llls: cannot open directory .: Permission denied[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ touch test.txt[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ llls: cannot open directory .: Permission denied[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ cd ..[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ chmod 577 newdr[yui@iZbp19b5lvg8xtpf1tzrenZ ~]$ cd newdr[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ lltotal 0-rw-rw-r-- 1 yui yui 0 Apr 28 15:46 test.txt[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ rm -f test.txtrm: cannot remove ‘test.txt’: Permission denied

总结:

x决定是否可以进入目录r决定是否可以查看文件属性信息w决定是否可以在目录下新建和删除文件

2.2 为什么我们创建的文件默认权限不是777

[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ mkdir test[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ lltotal 4drwxrwxr-x 2 yui yui 4096 Apr 28 15:49 test-rw-rw-r-- 1 yui yui    0 Apr 28 15:46 test.txt

我们可以看到,目录的默认权限为775,普通文件的默认权限为664。这是为什么呢?首先,我们要知道一个目录被创建出来天生就是要被进入、查看和修改的,因此目录的默认权限应该是777。普通文件则不一定需要执行权限,因此默认权限为666。但实际情况并不完全符合,这是因为在Linux下存在权限掩码,它可以定制文件创建时的默认权限。

2.2.1 关于Linux下的权限掩码指令 umask

功能:查看或修改文件的掩码格式:umask / umask 权限值说明:将现有的存取权限减去权限掩码后,即可产生建立文件时预设权限。root用户默认权限掩码为0022,普通用户默认为0002。实例:普通用户

[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ umask0002

root用户

[root@iZbp19b5lvg8xtpf1tzrenZ newdr]# whoamiroot[root@iZbp19b5lvg8xtpf1tzrenZ newdr]# umask0022

修改掩码

证件照制作小程序免费版 证件照制作小程序免费版

在线证件照系统是一套完善的冲印行业解决方案,致力于解决用户线上拍摄证件照,拍摄最美最标准证件照的使命。证件照免费版功能:后台统计:当天制作、当天新增、支持规格、近7日统计规格列表:筛选查看、编辑用户列表:筛选查看常见问题:筛选查看、新增、编辑、删除小程序设置:应用设置、流量主设置小程序跳转:筛选查看、新增、编辑、删除关注公众号:引导设置系统要求:系统:Linux系统(centos x64)运行环境

证件照制作小程序免费版 1 查看详情 证件照制作小程序免费版

[root@iZbp19b5lvg8xtpf1tzrenZ newdr]# su yui[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ umask0002[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ umask 0022[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ umask0022[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ umask 022[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ umask0022[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ umask 001[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ umask0001

修改掩码时,可以省略第一个0。计算文件创建时的默认权限。公式:文件的起始权限 & (~umask) = 最终权限(默认)。解释:目录的起始权限为0777,普通文件为0666。下面我来计算一个看看,就目录文件test吧,umask为0002。

[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ lltotal 4drwxrwxr-x 2 yui yui 4096 Apr 28 15:49 test-rw-rw-r-- 1 yui yui    0 Apr 28 15:46 test.txt

计算过程:

Linux——(关于权限常见的3个问题)

2.3 文件能否被删除取决于什么

我们来看看一个权限全无的文件:

[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ lltotal 4drwxrwxr-x 2 yui yui 4096 Apr 28 15:49 test-rw-rw-r-- 1 yui yui    0 Apr 28 15:46 test.txt[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ chmod 000 test.txt [yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ lltotal 4drwxrwxr-x 2 yui yui 4096 Apr 28 15:49 test---------- 1 yui yui    0 Apr 28 15:46 test.txt[yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ rm -f test.txt [yui@iZbp19b5lvg8xtpf1tzrenZ newdr]$ lltotal 4drwxrwxr-x 2 yui yui 4096 Apr 28 15:49 test

即使我对这个文件的权限什么都没有,但我却可以删除它。甚至root的文件也可以删除。因此我们明白了,一个文件能否被删除,不取决于文件本身,而是取决于文件所处的目录,即拥有者是否具有w权限。这样的话会不会很危险呢?确实,不过在现实情况下,你不会去别人的目录下写文件。那么就催生出了另一个问题,当需要小组合作时呢?为了解决这个问题,Linux下有一个共享文件夹。

2.3.1 Linux下的共享文件夹

唯一根目录下。

[yui@iZbp19b5lvg8xtpf1tzrenZ /]$ pwd/[yui@iZbp19b5lvg8xtpf1tzrenZ /]$ lltotal 72lrwxrwxrwx.  1 root root     7 Jul 11  2019 bin -> usr/bindrwxr-xr-x   3 root root  4096 Apr 21 14:26 blog-rw-r--r--   1 root root   664 Apr 21 14:12 blog.zipdr-xr-xr-x.  5 root root  4096 Jul 11  2019 bootdrwxr-xr-x   3 root root  4096 Apr 21 14:22 codedrwxr-xr-x  19 root root  2980 Feb 28 16:24 devdrwxr-xr-x. 77 root root  4096 Apr 25 19:54 etcdrwxr-xr-x.  4 root root  4096 Apr 25 19:53 homelrwxrwxrwx.  1 root root     7 Jul 11  2019 lib -> usr/liblrwxrwxrwx.  1 root root     9 Jul 11  2019 lib64 -> usr/lib64drwx------.  2 root root 16384 Jul 11  2019 lost+founddrwxr-xr-x.  2 root root  4096 Apr 11  2018 mediadrwxr-xr-x.  2 root root  4096 Apr 11  2018 mntdrwxr-xr-x.  2 root root  4096 Apr 11  2018 optdr-xr-xr-x  91 root root     0 Nov  3 21:00 procdr-xr-x---.  9 root root  4096 Apr 21 15:29 rootdrwxr-xr-x  23 root root   640 Apr 28 00:33 runlrwxrwxrwx.  1 root root     8 Jul 11  2019 sbin -> usr/sbindrwxr-xr-x.  2 root root  4096 Apr 11  2018 srvdr-xr-xr-x  13 root root     0 Dec  5 18:09 sysdrwxrwxrwt.  9 root root  4096 Apr 28 03:47 tmp /////////////// 共享文件夹tmp///////////////////////////drwxr-xr-x. 13 root root  4096 Jul 11  2019 usrdrwxr-xr-x. 19 root root  4096 Jul 11  2019 var

在这个文件夹下就可以进行暂时的小组合作。细心的同学可能注意到了,tmp的权限中的t。t作为一个粘滞位:给目录中的other设置的一个权限位,具有x的意义,同时也进一步对目录权限进行特殊限定。该目录下的文件,只有root或者文件的拥有者有权利进行删除,其他人一概不允许!这样就有效地防止了其他人对自己文件的删除。

以上就是Linux——(关于权限常见的3个问题)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/727275.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
AI工具省钱攻略:200元预算做出万元级精品课
上一篇 2025年11月25日 10:05:18
快手网页版官方平台(登录) 快手网页版在线刷视频进入
下一篇 2025年11月25日 10:05:29

相关推荐

  • 理解编程指令:当结果正确,但实现方式不符要求时

    本文探讨了在编程实践中,即使程序输出了正确的结果,但若其实现方式未能严格遵循既定指令,仍可能被视为“不正确”的问题。我们将通过具体示例,对比直接求和与累加求和两种实现策略,强调理解和遵守编程规范的重要性,以确保代码的健壮性、可维护性及符合项目要求。 在软件开发过程中,我们经常会遇到这样的情况:编写的…

    2026年5月10日
    000
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • 如何插入查询结果数据_SQL插入Select查询结果方法

    如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法

    使用INSERT INTO…SELECT语句可高效插入数据,通过NOT EXISTS、LEFT JOIN、MERGE语句或唯一约束避免重复;表结构不一致时可通过别名、类型转换、默认值或计算字段处理;结合存储过程可提升可维护性,支持参数化与动态SQL。 将查询结果数据插入到另一个表中,可以…

    2026年5月10日 用户投稿
    000
  • Discord.py 交互按钮超时与持久化解决方案

    本教程旨在解决Discord.py中交互按钮在一段时间后出现“This Interaction Failed”错误的问题。我们将深入探讨视图(View)的超时机制,并提供通过正确设置timeout参数以及利用bot.add_view()方法实现按钮持久化的具体方案,确保您的机器人交互功能稳定可靠,即…

    2026年5月10日
    000
  • c++如何实现UDP通信_c++基于UDP的网络通信示例

    UDP通信基于套接字实现,适用于实时性要求高的场景。1. 流程包括创建套接字、绑定地址(接收方)、发送(sendto)与接收(recvfrom)数据、关闭套接字;2. 服务端监听指定端口,接收客户端消息并回传;3. 客户端发送消息至服务端并接收响应;4. 跨平台需处理Winsock初始化与库链接,编…

    2026年5月10日
    100
  • 谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    使用谷歌浏览器的开发者工具截图步骤:1. 按ctrl+shift+i(windows/linux)或cmd+option+i(mac)打开开发者工具。2. 点击右上角三个点,选择”更多工具”,再选择”截图”。3. 选择截取整个页面。推荐的谷歌浏览器扩展…

    2026年5月10日 用户投稿
    100
  • JS如何实现迭代器?迭代器协议

    JavaScript中实现迭代器需遵循可迭代协议和迭代器协议,通过定义[Symbol.iterator]方法返回具备next()方法的迭代器对象,从而支持for…of和展开运算符;该机制统一了数据结构的遍历接口,实现惰性求值,适用于自定义对象、树、图及无限序列等复杂场景,提升代码通用性与…

    2026年5月10日
    100
  • Golang使用Protobuf定义接口与消息格式

    Protobuf通过字段编号实现兼容性,新增字段可忽略、删除字段可保留编号,确保新旧版本互操作,支持服务独立演进。 在Golang项目中,利用Protobuf定义接口和消息格式,本质上是为服务间通信构建了一套高效、类型安全且跨语言的契约。它让数据结构清晰可见,RPC调用标准化,极大地简化了分布式系统…

    2026年5月10日
    000
  • pycharm解析器怎么添加 解析器添加详细流程

    在pycharm中添加解析器的步骤包括:1) 打开pycharm并进入设置,2) 选择project interpreter,3) 点击齿轮图标并选择add,4) 选择解析器类型并配置路径,5) 点击ok完成添加。添加解析器后,选择合适的类型和版本,配置环境变量,并利用解析器的功能提高开发效率。 在…

    2026年5月10日
    000
  • HTML文档的基本结构是什么? 3分钟带你了解HTML文档基础框架

    html文档的基础结构由四部分组成:1. 声明,用于告知浏览器以html5标准模式解析页面,避免怪异模式导致的兼容性问题;2. 根元素,包裹整个文档内容,并可通过lang属性指定语言;3. 头部区域,包含元数据如设置字符编码、实现响应式布局、定义页面标题、引入css和favicon、加载脚本等;4.…

    2026年5月10日
    000
  • Android和iOS系统下,HTML+JS代码运行结果差异:为什么input宽度为0时,Android输入方向异常?

    Android和iOS系统HTML+JS代码运行差异分析:input宽度为0引发的Android输入方向异常 开发OTP输入组件时,我们发现一个有趣的现象:当input元素的宽度设置为0 (style=”width: 0;”)时,Android系统下的输入方向会异常,而iOS系统则正常工作。 移除w…

    2026年5月10日
    000
  • JavaScript Electron桌面应用

    答案:使用JavaScript开发%ignore_a_1%桌面应用需结合Web技术与Node.js,通过主进程管理窗口、渲染进程展示界面,并利用IPC通信,调用系统功能如文件对话框,最后用electron-builder打包发布,注意安全与进程职责分离。 用JavaScript开发Electron桌…

    2026年5月10日
    000
  • JavaScript设计原则_JavaScript可维护代码

    每个函数应只做一件事,如拆分数据处理与DOM操作,命名体现功能(如formatDate),长度控制在20行内;2. 使用清晰命名(如currentUser、isValid)减少注释依赖,关键逻辑注明“为什么”;3. 按功能模块化组织代码,如api.js处理请求,utils.js存放工具函数,使用im…

    2026年5月10日
    000
  • C++如何编译和链接_C++从源码到可执行文件的过程解析

    c++kquote>预处理展开宏和头文件,编译生成汇编代码,汇编转为机器码,链接合并目标文件与库生成可执行程序。 当你写完一段C++代码,比如一个简单的hello world程序,最终能运行起来,背后其实经历了一系列步骤:预处理、编译、汇编和链接。这个过程将人类可读的源码转换成机器可以执行的程…

    2026年5月10日
    000
  • Linux文件系统iostat命令使用技巧

    Linux文件系统iostat命令使用技巧Linux文件系统iostat命令使用技巧Linux文件系统iostat命令使用技巧Linux文件系统iostat命令使用技巧

    iostat是Linux系统中用于监控I/O设备负载的关键工具,能分析磁盘性能并识别瓶颈。默认输出包括CPU使用率和设备I/O统计,分为系统启动以来的平均值和当前采样周期数据。核心指标有:%util反映设备利用率,持续接近100%可能表示I/O瓶颈;await为平均I/O等待时间,过高说明响应变慢;…

    2026年5月10日 用户投稿
    000
  • 如何测试html5编码_测试HTML5页面编码兼容性方法【编码测试】

    HTML5页面编码兼容性测试需五步:一查meta charset是否正确且前置;二验HTTP响应头Content-Type charset是否为utf-8;三用file或chardet工具探测实际编码;四跨浏览器测试URL参数中中文、Emoji解析;五通过W3C验证服务检查编码声明与字节一致性。 如…

    2026年5月10日
    100
  • Python继承中父类属性的初始化与访问策略

    本文深入探讨python面向对象编程中,子类如何正确初始化和访问父类属性。重点分析`super().__init__()`的工作原理,解释在继承链中参数传递的重要性,并提供通过子类构造函数传递参数的解决方案。此外,针对子类需要与特定父类实例交互的场景,文章还介绍了组合(composition)模式的…

    2026年5月10日
    000
  • javascript生命周期钩子是什么_组件有哪些关键阶段?

    JavaScript原生无生命周期钩子,这是Vue、React等框架为组件设计的机制;Vue按创建、挂载、更新、卸载四阶段提供对应钩子,React类组件有明确生命周期方法,函数组件则通过useEffect模拟,其核心价值在于精准控制执行时机以避免DOM操作错误和内存泄漏。 JavaScript 本身…

    2026年5月10日
    100
  • 为什么专注如此重要?

    在快节奏的数字时代,程序员能否保持专注直接影响着代码质量、项目进度和错误率。 高效专注,才能在开发过程中游刃有余。本文将分享一些实用技巧,助您提升编程专注力,高效完成任务。 专注力为何如此重要? 专注力是程序员的核心竞争力。编码需要高度集中,处理细节、逻辑和问题,稍一分神就可能导致错误百出,返工耗时…

    2026年5月10日
    000
  • 后缀php怎么打开_php文件打开方式与运行环境搭建指南

    要打开PHP文件需根据用途选择方式:查看代码可用文本编辑器或IDE,运行则需服务器环境。推荐新手使用XAMPP、WAMP等集成环境,将文件放入htdocs目录后访问localhost;开发者可利用PHP内置服务器,命令行执行php -S localhost:8000运行;高级用户可手动配置Apach…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信