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

星夢妙者
发布: 2025-11-27 21:25:19
原创
527人浏览过
解决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)。

步骤如下:

  1. 下载最新的 CA 证书包:https://www.php.cn/link/5fe4dadcdb001d8566cd20e6d8a20251
  2. 将文件保存到服务器上的某个目录,例如:/path/to/cacert.pem
  3. 在 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速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号