我想知道是否可以通过system()以root身份执行命令.如果不是这样,是否有任何函数可以以root身份执行命令(或运行二进制文件),我可以在C代码上使用它?
解决方法@H_404_13@ 在我们想要普通用户执行root命令之前我们遇到了这种情况,这是我们的解决方案(使用setuID / SUID):假使,假设:
>用户名:汤姆
>组:gTom
> C程序文件:my_pro.c
第1步:编写C代码工具:my_sudo.c
...int main(int args,char *argv[]) { if (args < 2) printf("Usage: my_sudo [cmd] [arg1 arg2 ...]"); // cmd here is the shell cmd that you want execute in "my_pro" // you can check the shell cmd privilege here // example: if (argv[1] != "yum") return; we just allow yum execute here char cmd[MAX_CMD]; int i; for ( i = 2; i < args; i ++) { // concatenate the cmd,example: "yum install xxxxx" strcat(cmd," "); strcat(cmd,argv[i]); } system(cmd);}
第2步:编译my_sudo.c以获取my_sudo可执行文件
sudo chown root:gTom my_sudo // user root && gTom group sudo chmod 4550 my_sudo // use SUID to get root privilege #you will see my_sudo like this(ls -l) #-r-sr-x--- 1 root my_sudo 9028 Jul 19 10:09 my_sudo* #assume we put my_sudo to /usr/sbin/my_sudo
第3步:在您的C代码中
...int main() { ... system("/usr/bin/mysudo yum install xxxxx"); ...}#gcc && ls -l#-rwxr--r-- 1 Tom gTom 1895797 Jul 23 13:55 my_pro
第4步:执行./my_pro
您可以在没有sudo的情况下执行yum安装.
总结以上是内存溢出为你收集整理的如何以root身份执行命令全部内容,希望文章能够帮你解决如何以root身份执行命令所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)