2

我有一个名为 testResponse.php 的 php 文件,它只是:

<?php
 sleep(5);
 echo"go";
?>

现在,我使用 file_get_contents 从另一个页面调用这个文件,如下所示:

$start= microtime(true);
$opts = array('http' =>
    array(
        'method'  => 'GET',
        'timeout' => 1
    )
);

$context  = stream_context_create($opts);

$loc = @file_get_contents("http://www.mywebsite.com/testResponse.php", false, $context);
$end= microtime(true);
echo $end - $start, "\n";

输出超过 5 秒,这意味着我的超时已被忽略......我遵循了这篇文章的建议:stackoverflow.com/questions/3689371

但似乎主机名不能是路径(如 www.mywebsite.com/testResponse.php),而是直接是主机名,如 www.mywebsite.com。

所以我坚持要实现这个目标:

获取带有约束的页面 www.test.com/x.php 的内容:

  • 如果 test.com 不存在或页面 x.php 不存在,则不会快速返回任何内容
  • 如果页面存在但加载时间超过 1 秒,则中止
  • else 获取文件内容

编辑:顺便说一句,当我从本地服务器调用此页面(testResponse.php)时,它似乎可以工作。好吧,它将超时乘以 2。例如,如果我有 1 表示超时,我将回显类似“2.0054645”的内容。但只能从本地...

4

1 回答 1

4

解决方案是使用 PHP 的cURL 函数。您链接到的另一个问题正确地解释了有关读取超时连接超时等问题,但这些都不是您真正想要的。即使连接超时也不起作用,因为连接testResponse.php总是成功的;之后它正在等待,所以你需要的是执行超时。这就是 cURL 派上用场的地方。

所以,testResponse.php不需要改。但是,在您的主文件中,尝试以下代码(这是经过测试的,它可以在我的服务器上运行):

$start = microtime(true);
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "http://www.mywebsite.com/testResponse.php");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_TIMEOUT, 1);
$output = curl_exec($ch);
$errno = curl_errno($ch);
if ($errno > 0) {
    if ($errno === 28) {
        echo "Connection timed out.";
    }
    else {
        echo "Error #" . $errno . ": " . curl_error($ch);
    }
}
else {
    echo $output;
}
$end = microtime(true);
echo "<br><br>" . ($end - $start);
curl_close($ch);

这将通过您在第 5 行看到的选项设置 cURL 会话的执行时间CURLOPT_TIMEOUT。因此,当连接超时时,$errno将等于28cURL 操作超时错误的代码。其余错误代码列在 cURL 文档中,因此您可以扩展上面的脚本以采取相应措施。

最后,由于设置的CURLOPT_RETURNTRANSFER选项,curl_exec($ch)如果会话成功,将设置为检索到的页面的内容。否则,它将等于false

希望这可以帮助!

编辑:删除语句设置CURLOPT_HEADER。出于某种原因,我还认为curl_exec($ch)将 的值设置$ch为返回的内容,忘记了内容是由curl_exec().

于 2013-09-18T15:41:20.707 回答