【转】linux 设置用户id 设置组id
最近看apue,简单记录对设置用户id理解(设置组id同理)。
1. 相关的id好像很多,共有哪些?
文件2个id 2个位:
拥有者id 拥有者组id
设置用户id位 设置组id位
进程6个或更多的id(如果有附加组id):
实际用户id 实际组id (仅仅标志我们是谁,不参与文件访问权限检测)
有效用户id 有效组id (用于文件访问检测)
保存的设置用户id 保存的设置组id (有exec函数保存)
2. 进程打开、创建、删除文件时的权限测试?
测试的参与者是进程的有效用户id、有效组id、文件的拥有者id、文件拥有者组id。
(1)进程的有效用户id是0(超级用户),则允许访问;
(2)进程的有效用户id等于文件拥有者id,则按照拥有者的权限访问;
(3)进程有效组id或附加组id之一等于文件拥有者组id,则按照文件拥有者组的权限访问;
(4)否则,按照文件的其他用户访问权限访问;
上述的四步是按续依次进行的。
3. 什么时候用到设置用户id和设置组id?
当进程通过exec函数执行某个文件的时候,而且文件的设置用户id只会影响到进程的有效用户id
(其实也足够了,因为只有有效用户id参与权限测试),这样说不够严谨,因为进程的保存设置用
户id和保存设置组id会被exec函数从有效用户id和有效组id复制过来,所以保存的设置用户id和
保存的设置组id也会随之改变。
(1)当文件的设置用户id位和设置组id位没有打开:
进程的有效用户id和有效组id保持不变,严格按照第2步进行权限测试;
(2)文件的设置用户id位和设置组id位被打开:
exec函数才会把进程的有效用户id和有效组id设置为文件拥有者的用户id和组id,这时再进
行权限测试,进程就拥有了和文件拥有者一样的访问权限。
4. 进程保存设置用户id和保存设置组id有什么用?
顾名思义,这两个id存在的价值就是保存,保存谁呢?保存有效用户id和有效组id。当进程的
实际用户id和有效用户id不同时(组id同理),保存的设置用户id才有意义。因为这样就可以通
过调用setuid()把有效用户id切换为与进程的实际用户id或保存的设置用户id相同的值,不保存下
来,我们就弄丢了。
书上例子:
man程序文件的所有者及他属组通常是为man自身保留的用户和组, man可能需要执行许多其
他命令,以处理包含显示手册页的文件,为了防止被欺骗或重写错误文件, man在两种权限间
切换: 运行man命令用户的权限, 拥有man可执行文件用户的权限。下面列出其工作步骤:
(1)man拥有者是名为man的用户,且设置用户id位已经设置。当我们exec此程序时,用户id情况:
实际用户ID = 我们的用户ID
有效用户ID = man //设置用户id位已设置,有效用户id改变
保存的设置用户ID = man // 复制有效用户ID
(2) 进程访问需要的配置文件和手册页,这些文件由man用户拥有, 因为有效用户ID是man,
所以可以访问
(3)man 代表我们运行任一命令前, 调用setuid(getuid()) , 我们不是超级用户, 所以仅仅改变有效
用户ID,
用户ID情况变成:
实际用户ID = 我们的用户ID (未改变)
有效用户ID = 我们的用户ID
保存的设置用户ID = man //看出来了吧,如果不保存下来,我们就把man用户丢了,再想
setuid(man)就不会成功, 因为只允许将有效用户id设置为与实际用户id或保存的设置用户id
相同的值。 这时候,我们做回了自己,就只能访问我们通常可以访问的东西,没有特殊权限了。
man代表我们安全执行一次过滤。
(4)执行完过滤后,man再调用setuid(euid)(euid是man的数值用户id,man自己通过 geteuid
获得并保存的)。因为euid 等于保存的设置用户id,设置成功。(保存的设置用户id的价值所在)
得到:
实际用户ID = 我们的用户ID (未改变)
有效用户ID = man
保存的设置用户ID = man (未改变)
5) 因为有效用户是man, 所以现在可以对其他文件进行操作了
【转】linux 设置用户id 设置组id的更多相关文章
- 获取和设置用户id以及组id
#include<unistd.h> uid_t getuid(void); uid_t geteuid(void);//获取有效用户id gid_t getgid(void); gid_ ...
- 《UNIX环境高级编程》笔记--更改用户ID和组ID
在unix系统中,特权是基于用户和组ID的,当程序需要增加特权,或需要访问当前并不允许访问的资源时,我们需要更换自己 用户ID或组ID,使的新ID具有合适的特权或访问权限.与此类似,当程序需要降低其特 ...
- 进程控制之更改用户ID和组ID
在UNIX系统中,特权(例如能改变当前日期的表示法以及访问控制(例如,能否读.写一特定文件))是基于用户ID和组ID的.当程序需要增加特权,或需要访问当前并不允许访问的资源时,我们需要更换自己的用户I ...
- 更改用户id 和组id
转自 http://blog.csdn.net/todd911/article/details/16370577 在unix系统中,特权是基于用户和组ID的,当程序需要增加特权,或需要访问当前并不允许 ...
- linux 中将用户添加到组的 4 个方法
Linux 组是用于管理 Linux 中用户帐户的组织单位.对于 Linux 系统中的每一个用户和组,它都有惟一的数字标识号.它被称为 用户 ID(UID)和组 ID(GID).组的主要目的是为组的成 ...
- linux的用户管理、组管理
用户管理:centos系统是一个多用户系统 用户分为三类: 超级用户(root) 用户id为 0 伪用户 用户id为1-499,虽然存在,但是不能用户登录 普通用户 用户id为500-60000 用户 ...
- Day 5 Linux之用户、群组和权限
Linux之用户.群组和权限 一.各文件及内容对应含义 1./etc/passwd文件 功能:存储所有用户的相关信息,该文件也被称为用户信息数据库(Database). 含义:如下图所示. 2./et ...
- Linux id 命令 - 显示用户id和组id信息
要登入一台计算机,我们需要一个用户名.用户名是一个可以被计算机识别的身份.基于此,计算机会对使用这个用户名的登陆的人应用一系列的规则.在Linux系统下,我们可以使用 id 命令. 什么是 id 命令 ...
- 用户id,组id和文件访问权限
实际用户ID和实际组ID:标示了我们究竟是谁,这两个字段在登录时取自口令文件中的登录项 有效用户ID和有效组ID以及附属组ID:决定了我们的文件的访问权限(通常有效用户ID等于实际用户ID,有效组ID ...
- linux普通用户权限设置为超级用户权限方法、sudo不用登陆密码
以用户zato为例 普通用户权限设置为超级用户权限 进入有超级用户权限的账号 添加文件可写(w)权限 sudo chmod u+x /etc/sudoers 编辑/etc/sudoers文件 添加语句 ...
随机推荐
- 编写轻量ajax组件02-AjaxPro浅析
前言 上一篇介绍了在webform平台实现ajax的一些方式,并且实现一个基类.这一篇我们来看一个开源的组件:ajaxpro.虽然这是一个比较老的组件,不过实现思想和源码还是值得我们学习的.通过上一篇 ...
- echart折线图小知识
1)在折线图中,有时我们不想让太多折线显示,那么就隐藏,点击legend区域文字再显示. 比如我们要隐藏的折线叫"联盟广告",代码如下 var selected = {}; sel ...
- Djago模板拾起
在view中使用template: 首先在settings.py中配置模板文件的路径. TEMPLATE_DIRS = ( '/home/django/mysite/templates', ) 1.变 ...
- c风格字符串
1.字符数组截取 有当然有了,应均包含在<string.h>中. 有strncpy,strncat.可以帮你从任何位置,取得任意合法长度的字符串. 用法基本同strcpy,strcat. ...
- SSH(Struts2+Spring4+HIbernate5)的简化
今天给大家带来的是一个简单的新闻发布系统 首先在学习过程中我是深有体会,做事情不要浮躁,不要想着一口吃下一个胖子, 最最重要的是理解,理解透了学什么东西都是随心所欲的. 开发环境:win10系统 jd ...
- ContextFlyout 在10586或10240的使用
虽然ContextFlyout只能在红石以上版本使用,但可以采用附加属性的方法手动写一个 public static class ContextFlyoutSetter { public static ...
- Javascript JQuery获取当前元素的兄弟元素/上一个/下一个元素(转)
var chils= s.childNodes; //得到s的全部子节点 var par=s.parentNode; //得到s的父节点 var ns=s.nextSbiling; //获得s的下一个 ...
- ReactNative 使用微软的CodePush进行热更新,继续填坑
1.别被开发环境骗了 在我们开发react native的时候,一键运行工程,js改了,只要cmd+R就可以刷新了.然后会轻易以为真正app上线的时候也是一样,只要app一打开就是最新的. 其实!这是 ...
- theano broadcasting
当我们使用函数对两个数组进行计算时,函数会对这两个数组的对应元素进行计算,因此它要求这两个数组有相同的大小(shape相同).如果两个数组的shape不同的话,会进行如下的广播(broadcastin ...
- [Java] JSP笔记 - EL、JSTL 常用标签
一. 什么是 EL 语言 表达式语言(EL)是 JSP 2.0 引入的一种计算和输出 Java 对象的简单语言. 二.EL 语言的作用 为了使JSP写起来更加简单.表达式语言的灵感来自于 ECMASc ...