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

相关文章

linux hostname设置全过程

《linuxhostname设置全过程》:本文主要介绍linuxhostname设置全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录查询hostname设置步骤其它相关点hostid/etc/hostsEDChina编程A工具license破解注意事项总结以RHE

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

在Linux终端中统计非二进制文件行数的实现方法

《在Linux终端中统计非二进制文件行数的实现方法》在Linux系统中,有时需要统计非二进制文件(如CSV、TXT文件)的行数,而不希望手动打开文件进行查看,例如,在处理大型日志文件、数据文件时,了解... 目录在linux终端中统计非二进制文件的行数技术背景实现步骤1. 使用wc命令2. 使用grep命令

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信

linux重启命令有哪些? 7个实用的Linux系统重启命令汇总

《linux重启命令有哪些?7个实用的Linux系统重启命令汇总》Linux系统提供了多种重启命令,常用的包括shutdown-r、reboot、init6等,不同命令适用于不同场景,本文将详细... 在管理和维护 linux 服务器时,完成系统更新、故障排查或日常维护后,重启系统往往是必不可少的步骤。本文

基于Linux的ffmpeg python的关键帧抽取

《基于Linux的ffmpegpython的关键帧抽取》本文主要介绍了基于Linux的ffmpegpython的关键帧抽取,实现以按帧或时间间隔抽取关键帧,文中通过示例代码介绍的非常详细,对大家的学... 目录1.FFmpeg的环境配置1) 创建一个虚拟环境envjavascript2) ffmpeg-py

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删