0

我试图在手动搜索后调用 execv 以执行程序。

在我的例子中, c 是一个结构体,它的 args 是一个字符串数组,在接收输入时传递了参数。nargs 是参数的数量。c->args[0] 将包含 "ls","cat" 等。

我尝试在我的子进程中打印 args[0]、fullPath 等的值。它们都显示诸如“/bin/ls”、“/bin/cat”等值。但是当我调用 execv 时,它返回 -1,errno 为 2,我理解这是“没有这样的文件或目录”的错误. 但我确定该文件在那里,因为这就是我的 PathResolver 在检查所有权限后返回的内容。谁能指出我可能犯了错误的地方。

//发生在child内部的部分

  char *fullPath = PathResolver(c->args[0],1,&permission);
  printf("FullPath: %s -- Permission: %d\n",fullPath,permission);
  if(permission==0)
  {
      fprintf(stderr, "%s: Command not found\n",c->args[0]);
  }
  else if(permission==-1)
  {
      fprintf(stderr, "%s: Permission denied\n",c->args[0]);
  }
  else
  {
    char* args[c->nargs+1];
    int m=0;
    for(m=0;m<c->nargs;m++)
    {
          strcpy(args[m],c->args[m]);
    }
    args[c->nargs] = NULL;
    printf("%d\n",execv(args[0], args));
    printf("errno: %d\n",errno);
 }

路径解析器功能

   char* PathResolver(char *command, int ResolverMode, int *Permission)
   {
 *Permission = 0;
 char *returnString;
 returnString = malloc((sizeof(char)));
 char *strPath = getenv("PATH");
 char *del = ":";
 char *strToken = strtok(strPath,del);
 FILE *f;
 while(strToken)
 {
    char filePath[100];
    sprintf(filePath,"%s/%s",strToken,command);
    if(access(filePath,F_OK)>=0)
    {
        if(access(filePath,X_OK)>=0)
        {
            *Permission = 1;
            sprintf(returnString,"%s%s ",returnString,filePath);
            if(ResolverMode == 1)
                break;
        }
        else
        {
            *Permission = -1;
        }
    }
    strToken = strtok(NULL,del);
  }
  sprintf(returnString,"%s\b",returnString);
  return returnString;

}

4

2 回答 2

1

strcpy(args[m],c->args[m]);是未定义的行为,因为args[m]它不是指向有效内存的指针。

以下可能更简单:

char * args[c->nargs + 1];

for (size_t m = 0; m != c->nargs; ++m)
{
     args[m] = c->args[m];
}

args[c->nargs] = NULL;

无需复制字符串。

(这可能不是您的实际问题,但它肯定会阻止您的程序正确。)

于 2013-10-05T10:17:11.567 回答
0

execv()期望程序名称以完整路径作为第一个参数的前缀。

要进行PATH搜索而不是提供路径,请使用execvp().


更新

还有这条线

 returnString = malloc((sizeof(char)));

只为 分配1字节returnString,这对于您的使用方式来说很少returnString

于 2013-10-05T10:19:35.677 回答