PHP CURL CURLOPT_SSL_VERIFYPEER 被忽略

标签 php ssl curl https

由于某种原因,我无法将 CURL 与 HTTPS 一起使用。在我升级 curl 库之前,一切正常。现在我在尝试执行 CURL 请求时遇到此响应:SSL CA 证书有问题(路径?访问权限?)

根据此处发布的有关相关问题的建议,我尝试执行以下操作:

  • 禁用主机和对等方的验证

    curl_setopt($cHandler, CURLOPT_SSL_VERIFYHOST, false);
    curl_setopt($cHandler, CURLOPT_SSL_VERIFYPEER, true);
    
  • 启用 CURLOPT_SSL_VERIFYPEER 并指向从 http://curl.haxx.se/docs/caextract.html 下载的 cacert.pem

    curl_setopt($cHandler, CURLOPT_SSL_VERIFYPEER, true);  
    curl_setopt($cHandler, CURLOPT_CAINFO, getcwd() . "/positiveSSL.ca-bundle");
    
  • 我也尝试对作为我尝试连接的服务器的捆绑 CA 证书提供的 positiveSSL.ca-bundle 执行相同的操作。

  • 使用 curl.cainfo=cacert.pem 编辑 php ini 设置(文件在同一目录中,可供 apache 访问)

  • /etc/pki/nssdb 重命名为 /etc/pki/nssdb.old

不幸的是,上述方法都无法解决我的问题,并且我经常收到 SSL CA 证书问题(路径?访问权限?)消息。

而且我一开始就不需要这个验证(我知道安全问题)。

还有人有其他建议吗?

更新

在更新到最新的库并重新启动整个机器后,不仅仅是我正在做的 apache 现在似乎又可以工作了!!!

最佳答案

根据文档:要验证主机或对等证书,您需要使用 CURLOPT_CAINFO 选项指定备用证书,或者可以使用 CURLOPT_CAPATH 选项指定证书目录。

还请看CURLOPT_SSL_VERIFYHOST:

  • 1 检查 SSL 对等证书中是否存在通用名称。
  • 2 检查公用名称是否存在,并验证它是否与提供的主机名匹配。

curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);

关于PHP CURL CURLOPT_SSL_VERIFYPEER 被忽略,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15135834/

相关文章:

php - 托管在 iis 上时,嵌入 html 的 php 代码不执行

ssl - 为什么在向 sandbox.example.com 等任何子域发送请求时会出现此 SSL 错误?

ssl - IIS、TLS 和 SSL 版本或 C# 中的 SSL HttpWebRequest“无法创建 SSL/TLS 安全通道

C# SSL 连接被主动拒绝

php - 提高 CURL 速度 php

php - Nominatim 应用程序错误 PHP

php - 没有完整堆栈框架的 Symfony 组件

php - 绘制从 JSON php 导入到 Highcharts 的多个系列

php - Yii2/PHP/MySQL - 小数被截断,通过乘法给出错误结果

ssl - 当我在进行 SSL 调用时需要使用 SSL 私钥