linux – 可执行文件上的setuid似乎不起作用
我写了一个名为killSPR的小C实用程序来杀死RHEL盒子上的以下进程.这个想法适用于登??录这个linux盒子的人能够使用这个实用程序杀死下面提到的进程(这不起作用 – 如下所述).
该实用程序由用户cadmn(运行这些进程)拥有,并在其上设置了setuid标志(如下所示).
C代码如下:
与cadmn不同的用户(pmn)尝试使用此实用程序终止上述进程并失败(如下所示):
当用户等待上面的输入时,检查进程killSPR并且看作是作为用户cadmn运行(如下所示),尽管killSPR无法终止进程.
顺便说一句,没有一个主要分区有任何nosuid
可执行文件上的setuid标志似乎没有所需的效果.我在这里错过了什么?我误解了setuid是如何工作的吗? 最佳答案 首先,setuid位只允许脚本设置uid.该脚本仍需要调用setuid()或setreuid()以分别在真实uid或有效uid中运行.如果不调用setuid()或setreuid(),脚本仍将以调用脚本的用户身份运行. 避免系统和执行,因为他们出于安全原因删除权限.您可以使用kill()来终止进程. 检查这些. http://linux.die.net/man/2/setuid http://man7.org/linux/man-pages/man2/setreuid.2.html http://man7.org/linux/man-pages/man2/kill.2.html (编辑:安阳站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- linux – 当出现故障节点时,Heartbeat将无法从冷启动中成功
- 一篇学会Linux ptrace 的实践
- 支付宝元宵节红包口令是什么 支付宝元宵节红包口令答案
- 中国电信4g+什么时候普及 中国电信天翼4g+网络上市时间
- 手机解析包出现问题怎么办 手机解析包出现错误解决办法
- linux – Unix域套接字:accept()没有设置sun_path
- Linux 内核 5.19RC1推出完成了ARM通用内核的工作
- iPhone应用弹窗需要输入ID密码怎么办
- Fatal error: Call to undefined function json_decode()解
- linux – 检查是否在Bash中设置了陷阱