首页 > 系统相关 >linux之文件权限

linux之文件权限

时间:2024-11-15 10:46:31浏览次数:1  
标签:文件 权限 doc linux usera m01 txt root

文件权限管理

rwx含义

  • 是指在Linux系统中,文件的权限可读(r)、可写(w)、可执行(x)。

  • 文件权限是由三组rwx组成,开头第一位表示文件的类型为文件(-)、目录(d)、链接(l)等形式

rwx的数字概念

r 4
w 2
x 1
-rwxr-xr-x 
rwx #属主位
r-x #属组位
r-x #其它位
文件权限数字表示为:755

文件权限修改

# 修改文件的属主属组
chown 
[root@m01 ~]# chown usera.usera xiaoshuo.txt 
[root@m01 ~]# ll xiaoshuo.txt 
-rw-r--r-- 1 usera usera 0 Nov 15 08:59 xiaoshuo.txt

# 递归修改某个目录下所有文件属主属组
参数 -R 

# 修改文件权限
chmod
chmod u+rwx file
chmod o-rwx file
chmod u+x file
chmod g-w file
chmod o+x file
chmod o=rwx file

#使用数字进行修改文件权限
chmod 755 file

# 常用文件权限
644 rw-r--r--
755 rwxr-xr-x
600 rw-------

# 默认新建文件是644 
[root@m01 ~]# touch 1.txt
[root@m01 ~]# ll 1.txt 
-rw-r--r-- 1 root root 0 Nov 15 09:09 1.txt

# 默认新建目录是755
[root@m01 ~]# mkdir doc
[root@m01 ~]# ll -d doc/
drwxr-xr-x 2 root root 6 Nov 15 09:09 doc/

rwx对于文件的作用

# r对于文件的作用:
1.可读
2.不可写  但是可以强制写入
3.不能执行
4.不能删除 因为删除是由目录的权限控制的

# w对于文件的作用:
1.不能查看文件内容
2.不能使用vim方式写入 只能使用echo 追加内容
3.不能执行

# x对于文件的作用:
文件只要x权限,啥也干不了

总结:
1. 1个r对于文件有作用,只读
2. rw对于文件是最高权限可读写
3. r和x对于文件是有执行的权限
4. rwx脚本拥有最高的权限

rwx对于目录的作用

# 1. r权限对于目录的作用:
用户进不去,也看不了

[usera@m01 ~]$ ll -d doc
total 1
dr--rwxr-x 2 usera usera 6 Nov 15 09:21 doc
# 无法进入目录
[usera@m01 ~]$ cd doc/
-bash: cd: doc/: Permission denied
# 无法查看
[usera@m01 ~]$ cat doc/1.txt 
cat: doc/1.txt: Permission denied

# 2. w对于目录的作用:
只要w,啥也干不了

# 无法进入目录
[usera@m01 ~]$ cd doc/
-bash: cd: doc/: Permission denied
# 无法查看目录内容
[usera@m01 ~]$ cat doc/1.txt 
cat: doc/1.txt: Permission denied
# 无法新建文件
[usera@m01 ~]$ touch doc/2.txt
touch: cannot touch ‘doc/2.txt’: Permission denied

# 3. x对于目录的作用:
a.x控制是否可以cd到目录下
b.没有其他任何权限

[usera@m01 ~]$ ll -d doc/
d--xrwxr-x 2 usera usera 19 Nov 15 09:22 doc/
# 不能查看目录内容
[usera@m01 ~]$ ll doc/
ls: cannot open directory doc/: Permission denied
# 不能新建文件
[usera@m01 ~]$ touch doc/2.txt
touch: cannot touch ‘doc/2.txt’: Permission denied
# 能进入
[usera@m01 ~]$ cd doc/

# 目录权限的常用组合方式:
1.r-x组合作用 可以进入到目录可以查看目录下所有的文件信息 能不能看文件内容具体看文件的权限
2.r-x组合不能在目录下删除 创建 改名等动作
3.rwx组合目录的最高权限可以进入可以增删改查

umask值

umask作用决定默认创建文件和目录的权限
默认文件的权限: 644
默认目录的权限: 755

#文件默认权限: 是由文件的最高权限666减去umask值得到的
# umask值默认是0022 指的是root用户
[root@m01 ~]# umask 
0022

# 666 - 022 = 644
[root@m01 ~]# ll 2.txt 
-rw-r--r-- 1 root root 0 Nov 15 09:37 2.txt
# umask值默认是0002 指的是普通用户
[usera@m01 ~]$ umask 
0002
# 666-002=664
[usera@m01 ~]$ ll 2.txt 
-rw-rw-r-- 1 usera usera 0 Nov 15 09:36 2.txt

# root用户 创建目录 默认权限755
[root@m01 ~]# mkdir dr
[root@m01 ~]# ll -d dr
drwxr-xr-x 2 root root 6 Nov 15 09:41 dr
# 普通用户 创建目录 默认权限775
[usera@m01 ~]$ mkdir dir
[usera@m01 ~]$ ll -d dir/
drwxrwxr-x 2 usera usera 6 Nov 15 09:42 dir/

# 修改umask默认值
umask值存在奇数位,文件相减后再奇数位置+1,目录正常相减
[root@m01 ~]# umask
0032
文件权限: 666-032=634+010=644
目录权限: 777-032=745

隐藏权限位

#查看隐藏权限位
lsattr

#修改隐藏权限
chattr

# 修改2.txt 隐藏权限为a 追加
[root@m01 ~]# chattr +a 2.txt 
# 可以echo追加写入
[root@m01 ~]# echo "hell" >>2.txt 
# 可以查看
[root@m01 ~]# cat 2.txt 
hell
[root@m01 ~]# ll 2.txt 
-rw-r--r-- 1 root root 5 Nov 15 09:47 2.txt
# 不能删除
[root@m01 ~]# rm 2.txt 
rm: remove regular file ‘2.txt’? y
rm: cannot remove ‘2.txt’: Operation not permitted
# 不能清除重定向写入
[root@m01 ~]# echo "hell" >2.txt 
-bash: 2.txt: Operation not permitted
# 不能改名
[root@m01 ~]# mv 2.txt 22.txt
mv: cannot move ‘2.txt’ to ‘22.txt’: Operation not permitted
# 不能移动
[root@m01 ~]# mv 2.txt /opt/
mv: cannot move ‘2.txt’ to ‘/opt/2.txt’: Operation not permitted
# a隐藏权限 只允许追加写
[root@m01 ~]# lsattr 2.txt 
-----a---------- 2.txt

# 去掉a隐藏权限
[root@m01 ~]# chattr -a 2.txt 
[root@m01 ~]# lsattr 2.txt 
---------------- 2.txt

#i 无敌的 除了查看啥都不能干
[root@m01 ~]# chattr +i 2.txt 
[root@m01 ~]# lsattr 2.txt 
----i----------- 2.txt
[root@m01 ~]# echo hell >2.txt 
-bash: 2.txt: Permission denied
[root@m01 ~]# echo hell >>2.txt 
-bash: 2.txt: Permission denied
[root@m01 ~]# rm -f 2.txt 
rm: cannot remove ‘2.txt’: Operation not permitted
[root@m01 ~]# mv 2.txt /opt/
mv: cannot move ‘2.txt’ to ‘/opt/2.txt’: Operation not permitted
[root@m01 ~]# mv 2.txt 22.txt
mv: cannot move ‘2.txt’ to ‘22.txt’: Operation not permitted
# 只能查看
[root@m01 ~]# cat 2.txt 
hell

# 隐藏权限可以对一些特殊文件起到保护作用

特殊权限位

SUID, SGID, Sticky
# 作用 在用户执行命令的时候相当于属主的权限去执行。
# 给属主的位置增加s权限。任何人使用命令的时候相当于命令的属主的权限。

# SUID 
# 只能作用于二进制文件,可执行文件,进程已属主身份启动,并继承属主权限
#vim 编辑提权
#通过root身份修改vim权限,在u+s,普通用户使用vim编辑器相当于root编辑,此时可以修改/etc/passwd文件自己的uid为0,达到提权
chmod u+s /bin/vim
chmod 4755 /bin/vim
# 普通用户usera
vim /etc/passwd
usera:x:0:1000::/home/usera:/bin/bash
# 再次链接登录usera 成为root身份

# SGID 
# 作用于二进制或目录加上sgid权限后,该权限会自动继承原属组权限
# root身份新建目录 /opt/doc
mkdir /opt/doc/
chmod 2777 /opt/doc/
chmod g+s /opt/doc/
[usera@m01 opt]$ ll -d doc/
drwxrwsrwx 2 root root 6 Nov 15 10:41 doc/
# 普通用户新建文件 属组权限为root
[usera@m01 doc]$ touch 1.txt
[usera@m01 doc]$ ll
total 0
-rw-rw-r-- 1 usera root 0 Nov 15 10:42 1.txt

sgid目录下创建的文件和目录都会自动继承sgid权限。

# Sticky
chmod 1755 /mnt/
chmod o+t  /mnt/
# 目的,在同一个目录下,可共多个用户共同使用,且互不影响。


#作用范围及功能:
1.SUID:作用于文件(二进制程序)
此用户将继承此程序的所有者权限

2.SGID:作用于文件(二进制程序)和目录
对于文件:
此用户将继承此程序的所属组权限.
对于目录:
此文件夹下所有用户新建文件都自动继承此目录的用户组.

3.Sticky:作用于目录
设定后,目录中的用户只能删除、移动或改名自己的文件或目录

标签:文件,权限,doc,linux,usera,m01,txt,root
From: https://www.cnblogs.com/sharecorner/p/18547551

相关文章

  • 【ARM】MDK-烧录配置文件无权限访问
    【更多软件使用问题请点击亿道电子官方网站】1、问题场景客户代码编译正常、调试出现报错<Error:FlashDownloadfailed-"Cortex-M4">仿真器识别正常,keil-Debug内显示相关信息、设备启动正常。记录排查步骤,找到配置文件位置,查找相关文件,确认读取权限,后续成功烧录。......
  • Oracle VM VirtualBox Ubuntu设置共享文件夹方式
    https://www.jb51.net/database/323489zri.htmVirtualBox自带了一个增强工具SunVirtualBoxGuestAdditions,这是实现虚拟机与真实主机共享的关键。启动虚拟机后,点击控制菜单“设备”→“安装增强功能”,打开OracleVMVirtualBox,点击设置。点击“共享文件夹”。点击加号。......
  • HarmonyOS Next 分布式管理权限控制:安全与隐私
    本文旨在深入探讨华为鸿蒙HarmonyOSNext系统(截止目前API12)的技术细节,基于实际开发实践进行总结。主要作为技术分享与交流载体,难免错漏,欢迎各位同仁提出宝贵意见和问题,以便共同进步。本文为原创内容,任何形式的转载必须注明出处及原作者。在当今数字化时代,安全与隐私如同基石般重......
  • 1day未公开EyouCMS文件包含RCE漏洞 新接口
     0x01产品概述    1day未公开EyouCMS文件包含RCE漏洞 新接口用描述管理和发布于一体的智能化平台,广泛应用于新闻、媒体和各类内容创作机构。该平台支持多终端、多渠道的内容分发,具备素材管理、编辑加工、智能审核等功能,通过AI技术辅助内容创作与数据分析,提升内容......
  • Windows下搭建Cmake编译环境进行C/C++文件的编译
    文章目录1.下载Cmake2.安装MinGW-w643.进行C/C++文件的编译1.下载Cmake网址:https://cmake.org/download/  下载完成后安装,勾选“AddCMaketothesystemPATHforthecurrentuser"  点击Finish完成安装,在cmd窗口验证一下是否安装成功,出现如下图情况则安装成......
  • 速度与安全并重:交通运输业异地跨地区文件传输的创新方案!
    在交通运输业中,总部需要异地跨地区文件传输给分支机构的文件种类繁多,这些文件通常涵盖公司的战略规划、运营指导、规章制度、业务数据等多个方面。以下是一些常见的总部需要异地跨地区文件传输的文件类型:1.战略规划与考核文件:公司长期发展规划、年度经营计划、绩效考核标准及结果......
  • 【Windows】如何批量重命名文件?`ren`命令让你事半功倍
    如何批量重命名文件?ren命令让你事半功倍在日常工作中,我们经常需要对文件进行重命名,尤其是面对大量文件时,手动操作会非常耗时。Windows提供的ren命令可以轻松实现批量重命名的需求,让你事半功倍。本文将带你全面了解ren命令的使用方法,并提供几个实际应用场景,帮助你提高......
  • ABAP开发学习——权限控制
    目录概念常规应用SU01SU22PFCGSU53概念常规应用SU01:创建用户(SU01,SU02,SU03)SU22:查看事物码中的权限对象(SU20,SU21,SU22) PFCG:创建角色 SU53:权限测试(确认用户缺少权限)SU01SU22双击查看这里看到该权限根据采购组织来判断su21可以直接......
  • ABAP开发学习——权限控制 实例2
    目录自建权限对象 1.SU20,创建权限字段 2.SU21,创建权限对象 2.1先创建对象类ZCK.2.2在对象类中创建权限对象3.SU02,创建参数文件,维护权限值,并激活4.SU01,为用户分配参数文件5.SE38,编写程序及效果自建权限对象业务逻辑:建立一个ZTMM_TEST1,表中插入几条数据,实现只能......
  • Linux vi、vim
    在Linux学习,进行各种操作过程中需要用到很多种命令,本篇主要讲基础命令仅供大家参考。绝对是干货满满的一篇文章!!!vim底线模式提示:以下是本篇文章正文内容,仅供参考1.退出vim编辑器:        :W表示write,进行文本编辑写入内容,不会退出vim        :q表示quit,不......