Linux--文件权限与shell外壳的理解

目录

一.Linux的用户与用户切换,提权

二.对文件权限的理解

1.文件权限=角色的权限+文件属性

2.Linux中的三种角色

3.为什么会存在所属组这个角色

4.文件属性的意义

4.1.第一个字母的意义

4.2 第2——第10个字母的意义

4.3修改文件权限的方法

三.目录权限

四.权限的初始化与权限掩码umask

五.粘滞位

六.shell外壳


一.Linux的用户与用户切换,提权

Linux下由两种用户:超级用户(root),普通用户

超级用户:可以再 linux 系统下做任何事情,不受限制
普通用户:在 linux 下做有限的事情。
超级用户的命令提示符是 “#” ,普通用户的命令提示符是 “$

 命令:

su [用户名]

功能:切换用户

例如,要从 root 用户切换到普通用户 user ,则使用 su user 。 要从普通用户 user 切换到 root 用户则使用 su root( root 可以省略),此时系统会提示输入 root 用户的口令
命令:
su -

功能:切换到root

su[用户名]   与su -的区别:
su [用户名]:是单纯的用户切换,切换后路径不变
su - :让root账号重新登录,切换后到root的家目录

普通用户指令短暂提权至root

sudo 指令

注:使用sudo提权时,需要将当前普通用户添加到etc/sudoer中,sudo可以将后面的指令提权为root,在启动后第一次使用,需要输入当前用户的密码。接下来的几分钟再使用就不用再输密码。

为什么普通用户使用sudo提权,要输入当前用户密码,而非root密码?

我们知道,root用户可以无视一切权限,进行任意的操作。一旦root密码被非管理人员知道就可能造成一些未知的危险,因此为了让某些被信任的用户,可以执行一些需要root权限才可以做的事情,使用输入当前用户密码。同时这样也可以在遭受危险时,对人进行精准定责。

二.对文件权限的理解

1.文件权限=角色的权限+文件属性

对于Linux中的文件权限,有的角色对文件有读,写,执行的权限,而有的角色却什么都没有。这是人的权限。

注:对于可执行文件来说,只有他的具有可执行权限,并且文件内容为可执行内容。它才可以执行。


2.Linux中的三种角色

Linux中有三种角色:
owner          (拥有者)
grouper       (所属组)
other            (其他人)
文件权限限制的不是用户,而是这个用户对于文件所处的角色

3.为什么会存在所属组这个角色

这里举个例子:
一个公司想要开发一个软件,让A,B两个小组分别开发取其最好的。领导,A,B公用一台Linux云服务器。而对于A来说,它开发的东西,只想让A小组的人看到,不想B组的看到。因此把A组成员放在一个所属组中,将其它所属组的权限全部取消。这样其他组的成员就无权限访问A组文件,可以防止信息泄漏。

4.文件属性的意义

4.1.第一个字母的意义

第一个字母代表的时文件类型

在Windows系统中,区分文件类型是,通过文件名后缀,而Linux中,文件类型由文件属性的一个字母决定,与文件后缀无关。(Linux下为了方便我们快速区分文件类型,我们还是建议写上后缀。)

注:在使用一些工具时,文件必须加上对应的后缀。(如使用gcc编译文件时,文件必须以.c结尾)

d :文件夹
- :普通文件
l :软链接(类似 Windows 的快捷方式)
b :块设备文件(例如硬盘、光驱等)
p :管道文件
c :字符设备文件(键盘,显示器等串口设备)
s :socket套接口文件

4.2 第2——第10个字母的意义

他们三三为一组,共分为三组,分别代表着拥有者,所属组,其他用户的权限。r读权限,w写权限,x可执行权限,- 代表没有对应的权限

4.3修改文件权限的方法

chmod  角色 + / - 权限  文件名
功能:修改文件对应角色的权限
+: 向权限范围增加权限代号所表示的权限
-: 向权限范围取消权限代号所表示的权限
角色:  
u :拥有者
g :拥有者同组用
o :其它用户
a :所有用户
实例:
chmod u-r test     //将test文件拥有者的读权限取消
chmod g+x test     //将test文件所属组加上可执行权限
chmod o+rwx       //将test文件其他用户加上读,写,可执行权限
chmod u+r,g-w,o+x //对多个角色权限操作的组合
chmod a+rwx        //对所有角色的权限进行读,写,可执行权限的取消  

chmod 三位八进制数  文件名

功能:修改文件所有角色的权限

使用三个八进制数的原因:

三个:一共三个角色。

八位:文件有读,写,可执行三个权限,我们可以用二进制1表示拥有该权限,0表示无该权限。每个角色所有权限最大位7.

chmod 000 test //将test文件所有角色的权限全部取消

只有文件的拥有者和root才可以对文件角色的权限进行修改

角色的修改

sudo chown wzy test  //将test的拥有者修改为wzy
sudo chgrp wzy test  //将test的所属组修改为wzy
sudo chown wzy:wzy test //将test的拥有者,所属组修改为wzy

拥有者,所属组更改之后,other(其他用户)也会改变,所以不用特意去该。

三.目录权限

目录r权限:能否查看目录中的文件
目录w权限:能否在目录中创建,删除文件。
目录x权限:能否进入,执行目录中的文件。

四.权限的初始化与权限掩码umask

Linux规定,目录的起始权限是777,普通文件的起始权限是666.
那为什么我们创建出来的文件与目录并不是这样的呢?
原因: 权限=起始权限&umask
umask是什么?
umask是权限掩码,一般默认是0002(第一位不用管),凡是在umask中出现的权限,必须在起始权限中去掉。
修改umask的值
 
umask 0888 //将umask的值修改位0888

五.粘滞位

在使用Linux时,我们可能需要多个用户共同操作或访问一个文件,但是一个用户的文件不能被其他用户访问(root除外),因此为了实现这个要求,在所有用户中创造了一个所有用户都共享的文件(tmp),一般文件的拥有者是root。在这个目录里,所有用户都可以删除,创建文件。为了防止用户创造的文件被其他用户删除引入了粘滞位

注:粘滞位是针对的other(其他用户)

添加粘滞位:

chmod + t  目录名
当一个目录被设置为" 粘滞位 "( chmod +t), 则该目录下的文件只能由
一、超级管理员删除
二、该目录的所有者删除
三、该文件的所有者删除

六.shell外壳

Linux 严格意义上说的是一个操作系统,我们称之为 核心( kernel ,但我们一般用户,不能直接使用 kernel 。 而是通过kernel的 外壳 程序,也就是所谓的 shell ,来与 kernel 沟通。
从技术角度, Shell 的最简单定义:命令行解释器( command Interpreter )主要包含
将使用者的命令翻译给核心( kernel )处理。
同时,将核心的处理结果翻译给使用者。
理解:
对比 windows GUI ,我们操作 windows 不是直接操作 windows 内核,而是通过图形接口,点击,从而完成我们的
操作(比如进入 D 盘的操作,我们通常是双击 D 盘盘符 . 或者运行起来一个应用程序)。
shell 对于 Linux ,有相同的作用,主要是对我们的指令进行解析,解析指令给 Linux 内核。反馈结果在通过内核运 行出结果,通过shell 解析给用户。
对于用户指令,shell有如下操作:
1.拒绝用户非法请求,保护内核
当用户输入非法指令,shell不会询问内核,直接拒绝用户请求。
2.派生子进程执行用户指令
shell 使用户与操作系统沟通的唯一通道,一般shell不会直接执行指令,而是创造一个子进程,让这个子进程去执行指令。这样即使指令执行失败,shell让然不受影响。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/206098.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【1day】DocCms 某接口SQL注入漏洞学习

注:该文章来自作者日常学习笔记,请勿利用文章内的相关技术从事非法测试,如因此产生的一切不良后果与作者无关。 目录 一、漏洞描述 二、影响版本 三、资产测绘 四、漏洞复现 五、漏洞修

git分支修改名称并推送到远程

1. git branch -m oldBranchName newBranchName 修改本地分支名称,这将在本地仓库中重命名分支,但不会影响远程仓库。 2. git push origin :oldBranchName 命令用于删除远程仓库中的旧分支,通过将分支名前面的冒号 : 添加到命令中,可以将…

文本润色工具有哪些,高质量的文本润色软件

在当今信息过载的时代,文本的重要性愈发凸显。即便是最精心构思的文章,若未经过仔细的润色,也难以达到最佳的表达效果。本文将专心分享文本润色工具的种类。 文本润色工具的种类 文本润色工具根据其功能和应用范围可以分为多个种类&#xff…

GO设计模式——5、建造者模式(创建型)

目录 建造者模式(Builder Pattern) 建造者模式的核心角色 优缺点 使用场景 注意事项 代码实现 建造者模式(Builder Pattern) 建造者模式(Builder Pattern)是将一个复杂对象的构建与它的表示分离&…

js/jQuery常见操作 之 jQuery操作复选框的常见问题

js/jQuery常见操作 之 jQuery操作复选框的常见问题 1. js/jQuery的其他一些常见基础操作2. 全选/全不选问题2.1 效果2.2 实现代码2.2.1 简单js实现2.2.2 jQuery实现2.2.2.1 注意语法(区别jQuery版本)2.2.2.2 完整代码实现 3. jQuery实现点击 行tr 实现ch…

石头剪刀布python

石头剪刀布 import random AI_result [石头,剪刀,布] result random.choice(AI_result) User input("请输入石头/剪刀/布:") Win_list [[石头,剪刀],[剪刀,布],[布,石头]] print("AI出的",result,"玩家出的",User) if result …

【Java 基础】21 多线程同步与锁

文章目录 1.存在的问题2.使用同步解决问题1) synchronized2) volatile3) 锁 总结 用多线程过程中,有可能出现 多个线程同时处理(获取或修改等)同一个数据,这个时候就 会发生数据不同步的问题, 因此出现了同步和锁来…

APP备案(Android) - 获取签名证书公钥、MD5

因为近期刚针对各应用平台对APP备案时间节点要求进行了统一整理,然后隔天就被要求提供一下app相关的的公钥和MD5,虽然很快就解决了这个事情,但忍不住又稍微衍生了一下,但行小步,莫问远方吧 关联Blog APP备案(Android)…

ARM虚拟化与车联网安全应用

ARM虚拟化简介 ARM虚拟化是指在ARM架构下实现虚拟化技术的方法和技术。虚拟化技术允许在一台物理机上运行多个虚拟机实例,每个虚拟机实例都能够独立运行操作系统和应用程序。 ARM虚拟化的主要目标是提供高效、可扩展和安全的虚拟化环境。以下是一些关键概念和技术…

【docker】怎么查看docker镜像的dockerfile、docker history 显示不全

参考: https://blog.csdn.net/weixin_40161254/article/details/116458523 https://blog.csdn.net/m0_45406092/article/details/119037604 对于本地的镜像,我们使用docker history weblogic:latest 命令来查看它的构建命令,如图可以看到运…

芯知识 | 什么是单片机语音芯片?

在电子技术的飞速发展下,语音芯片成为了日常生活中不可或缺的一部分。而在语音芯片领域,单片机语音芯片占据了重要的地位。那么,究竟什么是单片机语音芯片呢? 一、定义与概念 首先,我们来了解一下单片机和语音芯片的…

java多线程(二)线程池

目录 java线程池 线程池应用场景: 如何创建线程池: 有什么区别: 不同线程池对应的应用场景 案例 输出结果 java线程池 Java线程池是一种预先创建一定数量的线程,并将任务提交给这些线程执行的机制。线程池可以避免频繁创建…

ExecutorService、Callable、Future实现有返回结果的多线程原理解析

原创/朱季谦 在并发多线程场景下,存在需要获取各线程的异步执行结果,这时,就可以通过ExecutorService线程池结合Callable、Future来实现。 我们先来写一个简单的例子—— public class ExecutorTest {public static void main(String[] ar…

Vulnhub项目:EMPIRE: BREAKOUT

一、靶机地址 靶机地址:Empire: Breakout ~ VulnHub 靶机介绍: 该靶机被定义为简单,但是如果没有找到,那就难度成中等了! 二、渗透过程 老三样,发现目标,这里用 arp-scan 确定靶机 ip&#…

Java基础50题:14. 使用方法求最大值(2种方法)

概述 使用方法求最大值。 创建方法求两个数的最大值max2,随后再写一个求3个数的最大值函数max3。 要求: 在max3这个方法中,调用max2函数,来实现3个数的最大值计算。 方法一 【代码】 public class P14 {public static int max…

Java File类详解(下)练习二

第四题 需求:删除一个多级文件夹 import java.io.File;/*** 删除一个多级目录*/ public class FileDeletion {public static void main(String[] args) {File f new File("H:\\test\\aaa");deleteDir(f);}public static void deleteDir(File dir){// 进…

算法___

文章目录 算法两数之和 算法 两数之和 题目如下图: 我的答案如下图: 我采用的是最笨的思路,直接暴力的两次循环,第一次外循环是取数组的第一个元素,然后内循环会遍历数组后面除第一个的所有元素,然后和…

android studio 提示错误 “Operation is not supported for read-only collection“

Android studio从长颈鹿升级到 新版本小刺猬 ,之后 新建项目build 一个小时之后运行,竟然提示如下错误, "Operation is not supported for read-only collection"wtf,尝试过 新建项目,clean项目,重新build …

【前端设计模式】之原型模式

原型模式特性 原型模式(Prototype Pattern)是一种创建型设计模式,它通过克隆现有对象来创建新对象,而不是通过实例化类。原型模式的主要特性包括: 原型对象:原型对象是一个已经存在的对象,它作…

DDD架构思想专栏二《领域层的决策设计思想详解》

如果不了解DDD基本概念的读者可以去看这篇文章,传送门:DDD架构思想专栏一《初识领域驱动设计DDD落地》-CSDN博客 前言介绍 在上一章节介绍了领域驱动设计的基本概念以及按照领域驱动设计的思想进行代码分层,但是仅仅只是从一个简单的分层结…