没有合适的资源?快使用搜索试试~ 我知道了~
《Linux与Unix shell编程指南(完整高清版)》1
需积分: 0 0 下载量 74 浏览量
2022-08-03
21:00:18
上传
评论
收藏 31.73MB PDF 举报
温馨提示
试读
356页
第1章 文件安全与权限为了防止未授权用户访问你的文件,可以在文件和目录上设置权限位。还可以设定文件在创建时所具有的缺省权限:这些只是整个系统安全问题中的一小部分
资源详情
资源评论
资源推荐
下载
第1章 件安全与权限
为防未授权户访问你的件,可以在件和录上设置权限位。还可以设定件
在创建时所具有的缺省权限:这些只是整个系统安全问题中的部分。在这我们并想
对系统安全问题的进全的探讨,只是介绍下有关件和录的安全问题。
本章包含以下内容:
• 件和录的权限。
• setuid。
• chown和c h g r p。
• umask。
• 符号链接。
创建件的户和他 (她)所属于的组拥有该件。件的属主可以设定谁具有读、写、执
该件的权限。当然,根户或系统管员可以改变任何普通户的设置。个件经
创建,就具有三种访问式:
1) 读,可以显示该件的内容。
2) 写,可以编辑或删除它。
3) 执,如果该件是个 s h e l l脚本或程序。
按照所针对的户,件的权限可分为三类:
1) 件属主,创建该件的户。
2) 同组户,拥有该件的户组中的任何户。
3) 其他户,即属于拥有该件的户组的某户。
1.1 件
当你创建个件的时候,系统保存有关该件的全部信息,包括:
• 件的位置。
• 件类型。
• 件度。
• 哪位户拥有该件,哪些户可以访问该件。
• i节点。
• 件的修改时间。
• 件的权限位。
让我们使 ls -l命令,来看个典型的件:
第部分 s h e l l
下让我们来分析下该命令所得结果的前两,看看都包含哪些信息:
total 4232:这告诉我们该录中所有件所占的空间。
- r w x r- x r- x:这是该件的权限位。如果除去最前的横杠,这共是 9个字符,他们
分别对应9个权限位。通过这些权限位,可以设定户对件的访问权限。这 9个字符可以分
为三组:
r w x:件属主权限 这是前三位
r- x:同组户权限 这是中间三位
r- x:其他户权限 这是最后三位
后我们还将对这些权限位作详细的介绍。出现在 r、w、x位置上的横杠表示相应的访
问权限被禁。
1 该件硬链接的数。
root 件的属主。
root 件的属主 r o o t所在的缺省组(也叫做r o o t )。
3578 字节来表示的件度,记住,是 K字节!
Oct 14 04:44 件的新时间。
dmesg 件名。
1.2 件类型
还记得前节所提到的件权限位前的那个字符吗?我们现在就解释下这个横杠
所代表的意思,件类型有七种,它可以从 ls -l命令所出的结果的第位看出,这七种类型
是:
d 录。
l 符号链接 (指向另个件)。
s 套接字件。
b 块设备件。
c 字符设备件。
p 命名管道件。
- 普通件,或者准确地说,属于以上种类型的件。
1.3 权限
让我们t o u c h命令创建个件:
$ touch myfile
现在对该录使ls -l 命令:
2 第部分 shell
下载
我们已经创建个空件,正如我们所希望的那样,第个横杠告诉我们该件是
个普通件。你将会发现所创建的件绝多数都是普通件或符号链接件 (后将会出现
多的符号链接件 )。
件属主权限 组户权限 其他户权限
r w - r- - r—
接下来的三个权限位是件属主所具有的权限;再接下来的三位是与你同组户所具有
的权限,这是 a d m i n组;最后三位是其他户所具有的权限。在该命令的结果中,我所属于
的缺省组也显示出来。下是对该件权限的精确描述:
表1-1 ls -l命令输出的含义
(第个字符 ) - 普通件
(接下来的三个字符) r w - 件属主的权限
(再接下来的三个字符 ) r- - 同组户的权限
(最后三个字符 ) r- - 其他户的权限
因此,这三组字符(除第个字符)分别定义:
1) 件属主所拥有的权限。
2) 件属主缺省组(个户可以属于很多的组 )所拥有的权限。
3) 系统中其他户的权限。
在每组字符中含有三个权限位:
r 读权限
w 写/改权限
x 执该脚本或程序的权限
这我们采另外种式来表示刚才所出 m y f i l e的件权限:
- r w - r- - r--
件类型为普通件 件属主可以读、写 同组户可以读 其他户可以读
你可能已经注意到,m y f i l e在创建的时候并未给属主赋予执权限,在户创建件时,
系统会动地设置执权限位。这是出于加强系统安全的考虑。必须修改这权限位:
后讲到 u m a s k命令时,你就会明为么没有获得执权限。然,你可以针对录设置执
权限位,但这与件执权限位的意义有所同,这点我们将在后讨论。
上这段关于权限位的内容可能太好解,让我们来看个 (表1 - 2 )。
令迷惑的是,对于件属主来说,在只有读权限位被置位的情况下,仍然可以通过
件重定向的法向该件写。过会我们就会看到,能否删除个件还依赖于该
件所在录权限位的设置。
表1-2 件权限及含义
权 限 所代表的含义
r-- --- --- 件属主可读,但能写或执
r-- r-- --- 件属主和同组户 (般来说,是件属主所在的缺省组 )可读
r-- r-- r- - 任何户都可读,但能写或执
rwx r-- r- - 件属主可读、写、执,同组户和其他户只可读
rwx r-x --- 件属主可读、写、执,同组户可读、执
第1章 件安全与权限 3
下载
(续)
权 限 所代表的含义
rwx r-x r- x 件属主可读、写、执,同组户和其他户可读、执
rw- rw- --- 件属主和同组户可读、写
rw- rw- r- - 件属主和同组户可读、写,其他户可读
rw- rw- --- 件属主和同组户及其他户读可以读、写,慎这种权限
设置,因为任何户都可以写该件
1.4 改变权限位
对于属于你的件,可以按照的需要改变其权限位的设置。在改变件权限位设置
之前,要仔细地想想有哪些户需要访问你的件 (包括你的录)。可以使 c h m o d命令来
改变件权限位的设置。这命令有较短的绝对模式和些的符号模式。我们先来看
看符号模式。
1.4.1 符号模式
c h m o d命令的般格式为:
chmod [who] operator [permission] filename
w h o的含义是:
u 件属主权限。
g 同组户权限。
o 其他户权限。
a 所有户 (件属主、同组户及其他户 )。
o p e r a t o r的含义:
+ 增加权限。
- 取消权限。
= 设定权限。
p e r m i s s i o n的含义:
r 读权限。
w 写权限。
x 执权限。
s 件属主和组s e t - I D。
t 粘性位*。
l 给件加锁,使其他户法访问。
u,g,o 针对件属主、同组户及其他户的操作。
*在件或录时,有时会遇到“ t”位。“ t”代表粘性位。如果在个录上出现
“ t”位,这就意味着该录中的件只有其属主才可以删除,即使某个同组户具有和属主
同等的权限。过有的系统在这规则上并分严格。
如果在件表时看到“ t”,那么这就意味着该脚本或程序在执时会被放在交换区 (虚
存)。过由于当今的内存价格如此之低,可必会件的“ t” 的使。
4 第部分 shell
下载
1.4.2 chmod命令举
现在让我们来看些使 c h m o d命令的。假定 m y f i l e件最初具有这样的权限: r w x
rwx rwx :
命 令 结 果 含 义
chmod a-x myfile rw- rw- rw- 收回所有户的执权限
chmod og-w myfile rw- r-- r- - 收回同组户和其他户的写权限
chmod g+w myfile rw- rw- r- - 赋予同组户写权限
chmod u+x myfile rwx rw- r- - 赋予件属主执权限
chmod go+x myfile rwx rwx r- x 赋予同组户和其他户执权限
当创建m y f i l e件时,它具有这样的权限:
如果这是我写的个脚本,我希望能够具有执权限,并取消其他户 (所有其他户 )
的写权限,可以:
$ chmod u+x o-w myfile
这样,该件的权限变为:
现在已经使件属主对 m y f i l e件具有读、写执的权限, a d m i n组的户对该件具
有读权限。
如果希望某个脚本件对你来说可执,且你对该件的缺省权限很放,那么
只要使它对你来说具有执权限即可。
$ chmod u+x dt
1.4.3 绝对模式
c h m o d命令绝对模式的般形式为:
chmod [mode] file
其中m o d e是个进制数。
在绝对模式中,权限部分有着同的含义。每个权限位个进制数来代表,如表
1 - 3所示。
表1-3 进制录/件权限表示
进 制 数 含 义 进 制 数 含 义
0 4 0 0 件属主可读 0 0 1 0 同组户可执
0 2 0 0 件属主可写 0 0 0 4 其他户可读
0 1 0 0 件属主可执 0 0 0 2 其他户可写
0 0 4 0 同组户可读 0 0 0 1 其他户可执
0 0 2 0 同组户可写
在设定权限的时候,只需按照表 1 - 3查出与件属主、同组户和其他户所具有的权限
相对应的数字,并把它们加起来,就是相应的权限表示。
从表1 - 3中可以看出,件属主、同组户和其他户分别所能够具有的最权限值就是7。
第1章 件安全与权限 5
下载
剩余355页未读,继续阅读
maXZero
- 粉丝: 23
- 资源: 303
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 基于QT的地图可视化桌面系统后台数据库为MySQL5.7源码.zip
- 基于simulink的PLL锁相环系统仿真【包括模型,文档,参考文献,操作步骤】
- 基于EM-GMM模型的目标跟踪和异常行为检测matlab仿真【包括程序,注释,参考文献,操作步骤,说明文档】
- 2109010044_胡晨燕_选课管理数据库设计与实现.prj
- 帕鲁介绍的PPT备份没什么好下的
- demo1-202405
- 两种方式修改Intel网卡MAC地址
- 服务器搭建所需资源:static文件夹
- Vue02的源码学习资料
- Python 程序语言设计模式思路-行为型模式:访问者模式:在不改变被访问对象结构的情况下,定义对其元素的新操作
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
评论0