如何以root身份执行命令

Ang*_*ngs 6 c linux root

我在Linux(Debian)上开发了一个C代码.有时,我需要执行一些命令system()

我想知道是否可以通过system()root 执行命令.如果不是这样,是否有任何函数可以以root身份执行命令(或运行二进制文件),我可以在C代码上使用它?

Yif*_*ang 4

之前我们遇到过这样的情况,我们想用普通用户执行root命令,这是我们的解决方案(使用setuid/SUID):

假使,假设:

  • 用户名Tom
  • 团体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);
} 
Run Code Online (Sandbox Code Playgroud)

第二步:编译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
Run Code Online (Sandbox Code Playgroud)

第 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
Run Code Online (Sandbox Code Playgroud)

第四步:执行./my_pro

您可以执行yum install没有sudo.

  • ⚠ 哎哟!您正在将参数连接为 shell 命令行!然后用户可以执行 `mysudo 'arg;sh'` 来获取 `root` shell。而且你并没有像“sudo”那样净化环境。 (6认同)