linux进程--setuid/setgid

2024-03-13 17:18
文章标签 linux 进程 setuid setgid

本文主要是介绍linux进程--setuid/setgid,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文件setuid/setgid标志位

linux文件的权限标志除了大家熟知的读(r)、写(w)、执行(x)外,还有三个比较特殊的权限位:setuid/setgid/sticky bit

setuid只作用于二进制可执行文件(不包含shell/python/perl等脚本),它允许当前用户以文件所有者的权限运行文件。

如系统的passwd命令

ls -l /usr/bin/passwd
-rwsr-xr-x 1 root root 54256 Mar 27 2019 /usr/bin/passwd

这个文件属于root用户,但其它用户有执行权限,那么当一个普通用户test运行passwd时,就暂时拥有了root权限。

setgid用于二进制可执行文件时与setuid类似,但当一个目录的setgid设置时,这个目录中新创建的文件及子目录会继承这个目录的gid,而不是创建者的gid,并且会继承目录的setgid标志。

sticky bit对文件没有影响,只作用于目录。 当一个目录的sticky标志位设置时,那么这个目录中的所有文件只能由其所有者移动或删除。一个典型的例子是/tmp目录,通常
系统中的所有用户都对这个目录有写权限,但设置sticky位使用户不能删除其它用户的文件。

进程的UID/RUID/EUID/SUID

UID: the user ID, 通常是指一个文件的拥有者。

RUID: the real user ID,调用程序的用户。例如:当test用户执行passwd时,那当前进程的RUID就是test.

EUID:the effective user ID, 如果程序文件的setuid位设置,当调用exec运行程序时,exec将EUID设置为程序文件的UID。进程运行时,它以UID的权限运行.例如: passwd命令设置了setuid,它的拥有者是root, 用户test调用了这个命令,那么当前进程实际上是以root的权限运行,RUID就是test,而EUID为root.

SUID: the saved set-user-ID, 当exec设置完EUID,将EUID复制到SUID.

假设有一个程序文件HelloWorld,它的拥有者是test,并且所有用户有执行权限。
1.如果HelloWorld文件的setuid没有设置,当用户rt2022通过exec运行它,那么

RUID = rt2022
EUID = rt2022
SUID = rt2022

2.如果HelloWorld文件的setuid设置,当用户rt2022通过exec运行它,那么

RUID = rt2022
EUID = test
SUID = test

setuid()/setgid()

#include <unistd.h>int setuid(uid_t uid);
int setgid(gid_t gid);

更改用户id、用户组id。如果进程具有root权限,则setuid将RUID/EUID/SUID设置为uid;如果进程没有root权限,但参数uid等于RUID或SUID,则setuid将EUID设置为uid; 如果前面两个条件都不满足,则返回-1,并设置errno为EPERM.

seteuid()/setegid()

#include <sys/types.h>
#include <unistd.h>int seteuid(uid_t euid);
int setegid(gid_t egid);

更改进程的EUID/EGID。 如果进程有root权限,则将EUID设置为euid; 如果进程没有root权限,但参数euid等于RUID或SUID,则将EUID设为euid.

getuid()/getgid()/geteuid()/getegid()

#include <unistd.h>
#include <sys/types.h>uid_t getuid(void); 
uid_t geteuid(void);   
gid_t getgid(void);
gid_t getegid(void);

分别为获取进程当前RUID/EUID//RGIDEGID

举例

假设root用户有一个程序文件HelloWorld及一个配置文件config, HelloWorld需要对config有读写权限,HelloWorld对所有用户是可执行的。

1.当test用户运行HelloWorld

RUID=test
EUID=root
SUID=root

2.因为HelloWorld有root权限,所以它可以读config. 当读完后,要进行一些处理,而此时并不需要root权限,所以HelloWorld调用seteuid,把EUID设置为test.(此时进程是root权限,所以可以设置成功)

RUID=test
EUID=test
SUID=root

3.当处理完成后,需要将结果写回config, 调用seteuid将EUID设置成root.(此时进程是test权限,但SUID=root,所以是可以设置成功的)

RUID=test
EUID=test
SUID=root

4.写完config后,进程再也不需要root权限,调用setuid将RUID/EUID/SUID设为test.

RUID=test
EUID=test
SUID=test

之后HelloWorld只能以test用户权限运行,再也无法获取root权限。

这篇关于linux进程--setuid/setgid的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/805595

相关文章

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Linux搭建ftp服务器的步骤

《Linux搭建ftp服务器的步骤》本文给大家分享Linux搭建ftp服务器的步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录ftp搭建1:下载vsftpd工具2:下载客户端工具3:进入配置文件目录vsftpd.conf配置文件4:

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet

Linux系统管理与进程任务管理方式

《Linux系统管理与进程任务管理方式》本文系统讲解Linux管理核心技能,涵盖引导流程、服务控制(Systemd与GRUB2)、进程管理(前台/后台运行、工具使用)、计划任务(at/cron)及常用... 目录引言一、linux系统引导过程与服务控制1.1 系统引导的五个关键阶段1.2 GRUB2的进化优

Linux查询服务器 IP 地址的命令详解

《Linux查询服务器IP地址的命令详解》在服务器管理和网络运维中,快速准确地获取服务器的IP地址是一项基本但至关重要的技能,下面我们来看看Linux中查询服务器IP的相关命令使用吧... 目录一、hostname 命令:简单高效的 IP 查询工具命令详解实际应用技巧注意事项二、ip 命令:新一代网络配置全

linux安装、更新、卸载anaconda实践

《linux安装、更新、卸载anaconda实践》Anaconda是基于conda的科学计算环境,集成1400+包及依赖,安装需下载脚本、接受协议、设置路径、配置环境变量,更新与卸载通过conda命令... 目录随意找一个目录下载安装脚本检查许可证协议,ENTER就可以安装完毕之后激活anaconda安装更

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详

Linux grep 命令的使用指南

《Linuxgrep命令的使用指南》本文给大家介绍Linuxgrep命令的使用指南,包括基础搜索语法、实践指南,感兴趣的朋友跟随小编一起看看吧... 目录linux grep 命令全面使用指南一、基础搜索语法1. 基本文本搜索2. 多文件搜索二、常用选项详解1. 输出控制选项2. 上下文控制选项三、正则表达

Linux部署中的文件大小写问题的解决方案

《Linux部署中的文件大小写问题的解决方案》在本地开发环境(Windows/macOS)一切正常,但部署到Linux服务器后出现模块加载错误,核心原因是Linux文件系统严格区分大小写,所以本文给大... 目录问题背景解决方案配置要求问题背景在本地开发环境(Windows/MACOS)一切正常,但部署到