我有一个 PHP 脚本,需要从另一个 PHP 网页中执行。但是,要使第二个正常运行,第一个需要完全完成。本质上,我需要第一页为第二个脚本生成一个新的进程/线程,该脚本将在开始前等待 1 秒。
执行包含会导致阻塞,从而阻止它工作,我无法让它开始使用 exec
编辑:
应该澄清的。这些页面没有输出,也没有通过 Web 界面进行交互。所有页面都由来自另一台服务器的 POST 请求调用。
编辑2:
解决方法:让请求页面的服务器在第一个返回后1秒直接向第二个页面发送请求。
我有一个 PHP 脚本,需要从另一个 PHP 网页中执行。但是,要使第二个正常运行,第一个需要完全完成。本质上,我需要第一页为第二个脚本生成一个新的进程/线程,该脚本将在开始前等待 1 秒。
执行包含会导致阻塞,从而阻止它工作,我无法让它开始使用 exec
编辑:
应该澄清的。这些页面没有输出,也没有通过 Web 界面进行交互。所有页面都由来自另一台服务器的 POST 请求调用。
编辑2:
解决方法:让请求页面的服务器在第一个返回后1秒直接向第二个页面发送请求。
一种选择是在第一个脚本完成后重定向页面。
你可以这样做:
//first script here
sleep(1); //wait one second
echo "<meta http-equiv=\"refresh\" content=\"0;URL='yoursecondscript.php'\" />"; //redirect
甚至:
//first script here
//redirect after one sec
echo "<meta http-equiv=\"refresh\" content=\"1;URL='http://thetudors.example.com/'\" />";
正如@ChristopherMorrissey 指出的那样,proc_open 是正确的选择。我想在这里详细说明一下,因为使用 proc_open 有一些注意事项并不完全清楚。
在第一个代码示例@ http://php.net/manual/en/function.proc-open.php中,它显示了整体用法,我将参考它。
第一个警告是管道。管道是 PHP 中的文件流,链接到子进程的 STDIN、STDOUT 和 STDERR。在示例中,管道索引 0 表示从父 PHP 进程角度看的文件流。如果父进程写入此流,它将显示为子进程的 STDIN 输入。
在符合 POSIX 的操作系统上,进程的 STDIN 需要在进程终止之前关闭。从父级调用管道上的 fclose 非常重要,否则您的子进程将被卡住。这是通过示例中的这一行完成的:
fclose($pipes[0]);
另一个警告是检查子进程的退出代码。检查退出代码是确定子进程是否正确退出或是否出错的最佳方法。至少,您只需要知道子进程何时完成。检查这个和退出代码都是用http://www.php.net/manual/en/function.proc-get-status.php完成的
如果要确保进程正确退出,则需要查看exitcode
proc_get_status 数组中返回的字段。请记住,此退出代码只会返回一次有效值。所有其他时间它将返回-1。因此,一旦它返回 > -1,这就是您的实际退出代码。所以,第一次running
== false,检查exitcode
.
我希望这有帮助。
您可以在需要时将页眉写入第二页,然后将页眉放回第二页末尾的原始页。尽管此修复不起作用的原因有很多,例如 PHP 代码需要在 HTML 中。
标题参考
所以像:header(Location: seconddocument.php)
或者,也许您可以将 PHP 放在一个函数中执行,然后从原始 PHP 文档中调用它。我不能完全确定您的要求,但这是我最好的两个答案。