解决PHP cURL访问HTTPS时SSL证书验证失败问题,可临时关闭验证(不推荐)或配置CA证书路径。1. 关闭验证:设CURLOPT_SSL_VERIFYPEER为false、CURLOPT_SSL_VERIFYHOST为false,仅用于测试。2. 推荐方案:下载cacert.pem并用CURLOPT_CAINFO指定路径,确保证书可信。3. 可在php.ini中设置curl.cainfo全局生效。生产环境必须启用验证以保障安全。

在使用 PHP 的 cURL 扩展读取 HTTPS 网页内容时,经常会遇到 SSL 证书验证失败的问题,比如目标网站使用了自签名证书、过期证书或 CA 不被信任。这时程序会抛出类似 "SSL certificate problem: unable to get local issuer certificate" 的错误。以下是几种解决方式,包括关闭证书校验和正确设置 CA 路径。
关闭 cURL 的 SSL 证书验证(不推荐用于生产)
如果你只是在测试环境或内网中使用,可以临时关闭 SSL 证书验证来获取网页内容。
通过设置以下两个 cURL 选项即可跳过证书检查:
CURLOPT_SSL_VERIFYPEER:设为 false,跳过对远程服务器证书的验证。 CURLOPT_SSL_VERIFYHOST:设为 false 或 0,表示不验证证书中的主机名。注意:这种做法存在安全风险,可能遭受中间人攻击,仅建议在开发调试时使用。示例代码:
Remusic Remusic - 免费的AI音乐、歌曲生成工具
514 查看详情
立即学习“PHP免费学习笔记(深入)”;
$ch = curl_init();curl_setopt($ch, CURLOPT_URL, "https://example.com");curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);// 关闭 SSL 证书验证curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);$content = curl_exec($ch);if (curl_error($ch)) { echo "cURL Error: " . curl_error($ch);} else { echo $content;}curl_close($ch);登录后复制设置正确的 CA 证书路径(推荐方案)
更安全的做法是让 cURL 使用可信的 CA 证书包进行验证。很多 PHP 环境默认没有配置 CA bundle,导致无法验证 HTTPS 证书。
你可以手动指定一个 CA 证书文件(如 Mozilla 提供的 cacert.pem)。
步骤如下:
下载最新的 CA 证书包:https://www.php.cn/link/5fe4dadcdb001d8566cd20e6d8a20251 将文件保存到服务器上的某个目录,例如:/path/to/cacert.pem 在 cURL 请求中指定该路径示例代码:
立即学习“PHP免费学习笔记(深入)”;
$ch = curl_init();curl_setopt($ch, CURLOPT_URL, "https://example.com");curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);// 启用证书验证curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, true);curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2); // 验证主机名// 指定 CA 证书路径curl_setopt($ch, CURLOPT_CAINFO, "/path/to/cacert.pem");$content = curl_exec($ch);if (curl_error($ch)) { echo "cURL Error: " . curl_error($ch);} else { echo $content;}curl_close($ch);登录后复制全局设置 CA 路径(php.ini 配置)
为了避免每次请求都手动设置 CA 路径,可以在 php.ini 中统一配置:
curl.cainfo = "/path/to/cacert.pem"登录后复制
这样所有使用 cURL 的 HTTPS 请求都会自动使用该 CA 文件进行验证。
修改后重启 Web 服务使配置生效。
其他注意事项
某些情况下即使设置了 CAINFO 仍可能失败,尤其是 Windows 系统上 WAMP/XAMPP 默认未配置证书路径。此时除了设置 CURLOPT_CAINFO,也可尝试设置:
curl_setopt($ch, CURLOPT_CAPATH, "/path/to/cert/dir"); // CA 证书所在目录登录后复制
但推荐优先使用 CURLOPT_CAINFO 指向具体的 pem 文件。
基本上就这些。生产环境务必开启证书验证并正确配置 CA 证书路径,避免因关闭校验带来的安全隐患。
以上就是php如何读取https网页内容避免证书错误_phpcurl关闭证书校验与CA路径设置的详细内容,更多请关注php中文网其它相关文章!
