首页 > 解决方案 > CURL 在 Red Hat、Apache、PHP、AWS 上的 Web 浏览器中不起作用

问题描述

我在运行 Apache 的 Red Hat AWS 服务器上有一个 PHP 脚本:

$url = "https://testsite.com/testfile.txt";
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$response = curl_exec($ch);
echo curl_error($ch);
$responseInfo = curl_getinfo($ch);
echo "http_code=".$responseInfo['http_code']."\n".$response."\n";
curl_close($ch);

当我从 SSH 终端运行它时,它可以工作。但是如果我在网络浏览器中加载页面,它会返回“http_code=0”。在这两种情况下, curl_error 都不返回任何内容。

我需要做什么才能允许 CURL 从 Web 浏览器工作?

标签: phplinuxamazon-web-servicescurlredhat

解决方案


由于没有产生错误,可以假设 curl 正在工作,但您没有得到想要的结果。

背后的原因可能不止一个——

首先检查安全组中的出站规则,它可能在那里失败

其次可能是由于https,尝试使用curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);

还要检查是否安装了 libcurl

如果尝试上述 3 件事都不起作用,则必须寻找其他可能性。


推荐阅读