为什么要在使用system()调用管理程序的setuid-c C程序中需要setuid(0)?

为什么要在使用system()调用管理程序的setuid-c C程序中需要setuid(0)?,第1张

概述我不得不为某人做一个脏的 Linux黑客攻击,所以他们可以使用cupsenable printername shell命令启动一个打印机,而非root用户.我不希望他们能够使用完整的cupsenable语法作为root,所以我刚刚写了一个C包装器,在argv [1]中对输入进行消毒,并调用system(“cupsenable sanitizedprintername”). 我做了程序setuid根 我不得不为某人做一个脏的 Linux黑客攻击,所以他们可以使用cupsenable printername shell命令启动一个打印机,而非root用户.我不希望他们能够使用完整的cupsenable语法作为root,所以我刚刚写了一个C包装器,在argv [1]中对输入进行消毒,并调用system(“cupsenable sanitizedprintername”).

我做了程序setuID根,但即使如此,cupsenable失败与“权限被拒绝”.然后我在system()之前插入了一个setuID(0)调用,并且看到它有效.

忽略有更好的方式给用户控制打印机的问题.可能有更好的方法.我感兴趣的是chmod的复杂与setuID(0)vs. system().为什么这样做呢?

解决方法 从人系统:

Do not use system() from a program with set-user-ID or set-group-ID privileges,because strange values for some environment variables might be used to subvert system integrity. Use the exec(3) family of functions instead,but not execlp(3) or execvp(3). system() will not,in fact,work properly from programs with set-user-ID or set-group-ID privileges on systems on which /bin/sh is bash version 2,since bash 2 drops privileges on startup.

和从男子bash:

If the shell is started with the effective user (group) ID not equal to the real user (group) ID,and the -p option is not supplIEd,no startup files are read,shell functions are not inherited from the environment,the SHELLOPTS variable,if it appears in the environment,is ignored,and the effective user ID is set to the real user ID.

看来你的setuID(0)电话规避了这种保护.

总结

以上是内存溢出为你收集整理的为什么要在使用system()调用管理程序的setuid-c C程序中需要setuid(0)?全部内容,希望文章能够帮你解决为什么要在使用system()调用管理程序的setuid-c C程序中需要setuid(0)?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1235674.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存