【发布时间】:2026-02-20 04:50:02
【问题描述】:
我查看了 * 上列出的每个解决方案。没有什么能解决这个问题。我遇到的问题只是当我将一个端口(在本例中为 5443)附加到 cURL PHP 代码时。如果我在没有端口的情况下执行 CLI,它就可以工作。在代码中,如果我只做一个直接的 URL https://HOSTNAME/api/test 而不分配端口,它就可以工作。无论哪种方式,我都可以看到 GET 进入。这都是关于认证验证的。服务器上的端口是开放的。
我有一个 GoDaddy G2 证书。我有一个带有 CA 包的新建服务器,我尝试使用根证书,来自
的证书包"https://curl.haxx.se/docs/caextract.html"
以及其他所有组合。添加端口号时,我总是遇到同样的错误:
“SSL 证书问题:无法获取本地颁发者证书”
$url = "https://HOSTNAME/api/test";
$curl = curl_init();
if ($curl === false)
{
echo "Failure";
} else
{
curl_setopt($curl, CURLOPT_PORT, 5443);
curl_setopt($curl, CURLOPT_HTTPGET, true);
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_CONNECTTIMEOUT, 5);
curl_setopt($curl, CURLOPT_TIMEOUT, 60);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
// Turn on SSL certificate verification
curl_setopt($curl, CURLOPT_CAPATH, "/fully_resolved_path/");
// and tried this way too
curl_setopt($curl, CURLOPT_CAPATH, "/fully_resolved_path");
// 试过了
curl_setopt($curl,CURLOPT_CAINFO,"/fully_resolved_path/cacert.pem");
//这个其实是默认设置,不再支持1,在这种情况下对最终结果没有影响。
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 2);
// 当这是 TRUE 时失败! FALSE 时不执行检查
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, TRUE);
$result = curl_exec($curl);
if ($result === false)
{
echo curl_error($curl);
} else
{
echo $result;
}
curl_close($curl);
}
一切都按预期设置并工作,返回一个 JSON 对象。只有当我添加端口号时,它才会窒息。 SSL 证书中的公用名与主机名匹配。如前所述,在我添加端口号之前它可以正常工作。
【问题讨论】: