7

我正在开发一个服务器应用程序,最近在测试服务器(Debian Squeeze)上遇到了这个奇怪的错误。

我传递给popen的每个可执行文件都失败并带有一条消息:

sh: sort: not found // happens to any command

无论我是指向“类型”返回的完整路径还是保持简短,都会发生这种情况。如前所述,这仅在一个测试环境中发生,为了增加混乱,运行相同的操作系统并且没有任何问题。

Popen 显然使用sh来执行命令,但是如果我通过命令行(bash 或 sh)运行相同的命令,一切都很好

提前致谢

(PS:甚至尝试过 Python os.popen 只是为了解决这个问题,它确实有效!)

编辑 这是一个失败的简单调用:

$command="tail -10 myfile";
$handle = popen($command.' 2>&1','r');
if($handle){
  while (!feof($handle)){
  ....//process buffer
  }
}

返回:

sh: tail: not found
4

2 回答 2

1

调用 popen 时,可能您的 PATH 配置不正确。我猜这是一个 PHP 配置问题,但您可以通过以下方式绕过它:

  1. 运行which tail以确定尾部程序的完整路径。
  2. popen使用 1 中找到的路径调用。
于 2010-04-27T02:02:55.693 回答
0

我在搜索我自己关于完全相同输出的答案时发现了这个问题。尽管我使用 C 进行编码,但我仍在使用 popen()。我是 C 的初学者,发现我犯了以下错误。

我正在回答这个问题,希望它可能对其他搜索相同错误消息的人有用。这就是我遇到、发现和纠正问题的方式。

我声明了一个字符串并将其他字符串与它连接起来以制定我的命令行。

我将该行打印到 stdout 以验证它是我想要的命令。从标准输出复制并执行时,该行有效。那么为什么 shell 会被 popen() 阻塞呢?

我将输出通过管道传输到一个文件并在编辑器中打开该文件,并看到当我的空字符串被初始化时,使用该字符串创建了特殊字符“^A”,该字符串未显示在终端上。

我改变了我声明 char 数组的方式:

字符变量名[];

对此:

字符变量名[512] = {""};

这解决了这个问题。我会鼓励任何有类似问题的人在与 popen() 一起使用的字符串中查找隐藏字符。

于 2016-02-18T16:57:25.753 回答