首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | 服务器技术 | linux相关 | linux认证 | 嵌入式 | 下载中心 | 专题 | linux招聘 | 镜像站
OKLinux中文技术站
·设为首页
·加入收藏
·联系我们
系统管理: 中文环境 系统管理 桌面应用 内核技术 | Linux基础: 基础入门 安装配置 常用命令 经验技巧 软件应用 | Linux数据库: Mysql Postgre Oracle DB2 Sybase other
网络管理: 网络安全 网络应用 Linux服务器 环境配置 黑客安全 | 编程开发: PHP CC++ Python Perl Shell 嵌入式开发 java jsp | PHP技术: PHP基础 PHP技巧 PHP应用 PHP文摘
Linux资讯 Linux招聘 Linux专题 Apache | Linux相关: 硬件相关 Linux解决方案 Linux认证 企业应用 其它Unix | 相关下载: 资料下载 参考手册 开发工具 服务器类 软路由 其它
 技术搜索:
会员中心 注册会员 高级搜索  
  → 当前位置:首页>linux基础>基础入门>正文

Linux系统的文件属性详细解析(二)

http://www.oklinux.cn  2007-10-15  来源:  kit  会员收藏  游客收藏  【 】 

5、setuid和setgid 位;

 

本部份内容做为了解,看看就行了;

 

5.1 setuid和setgid的解说 ;

 

setuid 和setgid位是让普通用户可以以root用户的角色运行只有root帐号才能运行的程序或命令。比如我们用普通用户运行passwd命令来更改自己的口令,实际上最终更改的是/etc/passwd文件。我们知道/etc/passwd文件是用户管理的配置文件,只有root权限的用户才能更改。

 

[root@localhost ~]# ls -l /etc/passwd

-rw-r--r-- 1 root root 2379 04-21 13:18 /etc/passwd

 

作为普通用户如果修改自己的口令通过修改/etc/passwd肯定是不可完成的任务,但是不是可以通过一个命令来修改呢。答案是肯定的,作为普通用户可以通过passwd 来修改自己的口令。这归功于passwd命令的权限。我们来看一下;

 

[root@localhost ~]# ls -l /usr/bin/passwd

-r-s--x--x 1 root root 21944 02-12 16:15 /usr/bin/passwd

 

因为/usr/bin/passwd 文件已经设置了setuid 权限位(也就是r-s--x--x中的s),所以普通用户能临时变成root,间接的修改/etc/passwd,以达到修改自己口令的权限。

 

我们知道Linux的用户管理是极为严格的,不同的用户拥有不同的权限,为了完成只有root用户才能完成的工作,我们必须为普通用户提升权限,最常用的方法就是su或sudo。虽然setuid 和setgid也是让普通用户超越自身拥有的普通权限达到root权限的方法,但我不推荐大家使用,因为它能为系统带来安全隐患!!

 

注意:setuid和setgid会面临风险,所以尽可能的少用,了解了解既可~~~

 

5.2 setuid和setgid的实例应用;

 

我们想让一个普通用户beinan拥有root用户拥有超级rm删除权限,我们除了用su或sudo 临时切换到 root身份操作以外,还能怎么做呢???

 

[root@localhost ~]#cd /home 注:进入/home目录

[root@localhost home]# touch beinantest.txt 注:创建一个测试文件;

[root@localhost home]# ls -l beinantest.txt 注:查看文件属性;

-rw-r--r-- 1 root root 0 04-24 18:03 beinantest.txt 注:文件的属性;

[root@localhost home]# su beinan 注:切换到普通用户 beinan

[beinan@localhost home]$ rm -rf beinantest.txt 注:以普通用户身份来删除beinantest.txt文件;

rm: 无法删除 “beinantest.txt”: 权限不够

 

那我们怎么才能让beinan 这个普通用户也拥有root超级的rm 删除功力呢?

 

[root@localhost ~]# ls -l /bin/rm

-rwxr-xr-x 1 root root 93876 02-11 14:43 /bin/rm

[root@localhost ~]# chmod 4755 /bin/rm 注:设置rm的权限为4755 , 就把setuid 位设置好了。

[root@localhost ~]# ls -l /bin/rm

-rwsr-xr-x 1 root root 43980 02-11 14:43 /bin/rm

[root@localhost ~]# cd /home/

[root@localhost home]# su beinan 注:切换到beinan用户身份;

[root@localhost home]$ ls -l beinantest.txt 注:查看文件属性;

-rw-r--r-- 1 root root 0 04-24 18:03 beinantest.txt 注:文件的属性;

[beinan@localhost home]$ rm -rf beinantest.txt 注:删除beinantest.txt文件;

 

我们只是设置了rm的setuid位,让普通用户在rm指令上有超级root的删除超级权力。

 

通过这个例子,我们应该能明白setuid和setgid位的应用了,如同前面所说,让普通用户超越本身的能力,让普通用户能执行只有root才能执行的命令。在这一点,我们要和su和sudo 区分开来。

 

5.3 setuid和setgid的设置方法;

 

第一种方法:八进制方法:

 

setuid位是的设置用八进制的4000,setgid占用的是八进制的2000 ;比如我们前面所说的 chmod 4755 /bin/rm 就是设置的setuid位;

 

至于setuid的设置方法,只是在我们通过chmod设置文件或目录权限位的八进制方法的前面多加一个数字,也就是4。比如:

 

[root@localhost ~]# chmod 4755 /bin/rm 注:设置rm的权限为4755 , 就把setuid 位设置好了。

 

作为setgid 位占用的是八进制的2000位,我们下面举个例子;

 

[root@localhost ~]# cd /home/

[root@localhost home]# mkdir slackdir

[root@localhost home]# ls -ld slackdir/

drwxr-xr-x 2 root root 4096 04-24 18:25 slackdir/

[root@localhost home]# chmod 2755 slackdir/

[root@localhost home]# ls -ld slackdir/

drwxr-sr-x 2 root root 4096 04-24 18:25 slackdir/

 

我们看到 slackdir这个目录,经过改变权限后的,目录所归属用户组的那三个权限位是 r-s。 如果我们见到的是小写的s,表明文件所归属的用户组位有执行权限x。因为我们用了2755 ,意思是说文件属主拥有可读可写可执行权限,所归属的用户组拥有可读可执行权限,并且设置了setuid,所以这时本来文件所归属的用户组拥有r-x,现在加了setgid位,就把其中的x换成了s。如果文件所归属的用户组没有执行权限,这个权限应该是S。同理setuid位的中的大写的S和小写的s,也是这个原理。

 

见下面的例子;

 

[root@localhost home]# chmod 2740 slackdir/

[root@localhost home]# ls -ld slackdir/

drwxr-S--- 2 root root 4096 04-24 18:25 slackdir/

 

这个例子是因为目录slackdir所归属的组没有执行权限,这时本来在执行权限位上显示-,由于有了setuid,所以显示为S。

 

如果我们为一个文件的权限拥有 属主可读可写可执行、所归的组拥有可读可执行,其它用户可读可执行,并且同时设置setuid和setgid位,我们应该怎么运行命令呢?

 

[root@localhost ~]# touch gooddoc.txt

[root@localhost ~]# ls -l gooddoc.txt

-rw-r--r-- 1 root root 0 04-24 18:47 gooddoc.txt

[root@localhost ~]# chmod 6755 gooddoc.txt

[root@localhost ~]# ls -l gooddoc.txt

-rwsr-sr-x 1 root root 0 04-24 18:47 gooddoc.txt

共4页: 上一页 1 [2] [3] [4] 下一页

上一篇:Firefox for Linux汉化的方法   下一篇:Fcitx小企鹅输入法在LumaQQ软件中的设置


收藏于收藏夹】 【评论】 【推荐】 【打印】 【关闭
相关文档
·常用的正则表达式操作符介绍
·Linux系统下X终端的使用方法
·Linux系统下图形界面与命令行模式的切换
·Linux操作系统的启动步骤说明
·Linux如何理解用数字表示文件的操作权限
·Linux操作系统中安装网卡驱动
·Linux系统为何会对计算机病毒免疫?
·Linux操作系统对虚拟内存的限制
·Linux文件系统Ext3与ReiserFS介绍
·Linux 等自由软件的扩散特性
·Linux操作系统RPM与TAR的基本安装和卸载
·修改Linux系统最大打开文件数
·Linux系统 /etc/fstab各个字段含义解释
·全方位接触 Linux的声音系统
·如何查看 Ubuntu Linux 各个版本的信息
·让你知道Linux下一般软件的安装在什么目录
发表评论
密码: 匿名评论
评论内容:

(不超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规)
 
  最新文档
·Ubuntu Linux系统的启动过程
·Ubuntu Linux系统下自启动选项设置方法
·Linux系统下文件和文件夹的复制问题
·Linux下如何解包和打包initrd image文
·虚拟机中Linux不能引导的问题
·Linux系统下修改字符集的方法
·Linux操作系统中连接库的生成
·Linux操作系统默认打开文件数
·Linux操作系统的错误诊断方法
·概括介绍Linux支持的文件系统
·Linux操作系统的RPM使用详解
·关于Linux操作系统的网卡编译
  阅读排行
·Linux的GRUB引导程序配置方法大全
·新手从零开始:Linux系统命令的使用
·Linux下tar bz gz等压缩包的压缩和解压
·从硬盘启动Desktop ISO所需的引导文件
·Linux系统面面观 PROC文件系统详细介绍
·Unix Shell程序编写的方法详解
·深入理解软件包的配置、编译与安装方法
·Linux操作系统下关于引导和初始化的问
·Linux操作系统的命令分类介绍
·Linux基础知识普及 理解GNU/Linux含义
·新手看招 Unix和Linux下C语言学习指南
·Linux命令Man解释Lilo:安装引导装载程
·Linux下挂载硬盘光驱和U盘的方法
·在Redhat AS4中加载NTFS分区的方法详解
·Linux操作系统的历史及其发展状况
网摘收藏: