欢迎来到全国社交动力网络科技有限公司
建站资讯

当前位置: 首页 > 建站资讯 > 建站教程 > PHP教程

php如何读取https网页内容避免证书错误_phpcurl关闭证书校验与CA路径设置

作者:小程序开发制作 来源:php教程百度云日期:2025-11-27
解决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如何读取https网页内容避免证书错误_phpcurl关闭证书校验与ca路径设置

在使用 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

Remusic - 免费的AI音乐、歌曲生成工具

Remusic 514 查看详情 Remusic

立即学习“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中文网其它相关文章!

标签: php菜鸟教程
上一篇: 教你免费获得网址加V绿钩认证,解决"安全性未知请,谨慎访问"
下一篇: php如何实现表单重复提交防护_php令牌验证与前端配合方案

推荐建站资讯

更多>