0

0

网页嵌入php链接失败SSL证书有问题咋办_网页嵌入php链接失败SSL排查法【解决】

蓮花仙者

蓮花仙者

发布时间:2025-12-24 12:58:45

|

919人浏览过

|

来源于php中文网

原创

PHP HTTPS请求SSL错误的解决方法包括:一、验证证书有效性与域名匹配;二、开发环境临时禁用cURL SSL验证;三、部署完整证书链;四、指定CA证书路径;五、校准服务器时间。

网页嵌入php链接失败ssl证书有问题咋办_网页嵌入php链接失败ssl排查法【解决】

如果您在网页中嵌入 PHP 链接时失败,且浏览器控制台或服务器日志提示 SSL 证书相关错误,则可能是由于证书不被信任、域名不匹配、证书过期或本地环境未正确验证证书链所致。以下是解决此问题的步骤:

一、检查证书有效性与域名匹配

SSL 证书必须由受信任的证书颁发机构(CA)签发,且其 Subject Alternative Name(SAN)或 Common Name(CN)需精确匹配当前请求的域名。若使用自签名证书或测试证书,现代浏览器和 PHP cURL 默认拒绝建立连接。

1、在浏览器地址栏访问该 PHP 接口 URL,点击地址栏锁形图标,查看证书详情,确认“有效期”是否在当前时间范围内。

2、核对证书中显示的“颁发给”字段,确保与您代码中调用的域名完全一致(包括 www 与非 www、子域名层级)。

立即学习PHP免费学习笔记(深入)”;

3、在终端执行:openssl s_client -connect example.com:443 -servername example.com 2>/dev/null | openssl x509 -noout -text,检查 SAN 列表是否包含实际使用的域名。

二、禁用 PHP cURL 的 SSL 验证(仅限开发环境)

PHP 使用 cURL 请求 HTTPS 资源时,默认启用 CURLOPT_SSL_VERIFYPEER 和 CURLOPT_SSL_VERIFYHOST,强制校验证书。临时绕过可快速定位是否为证书问题,但严禁用于生产环境

1、在调用 curl_init() 后立即设置:curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);

2、追加设置:curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);

3、确保上述两行在 curl_exec() 前执行,且未被其他配置覆盖。

三、部署完整证书链并配置 Web 服务器

部分 Nginx/Apache 配置仅加载站点证书,未包含中间证书(Intermediate CA),导致客户端无法构建可信链。PHP 客户端依赖系统 CA 存储或指定的 CA bundle,若链不完整则校验失败。

1、从证书提供商处下载完整的证书包(通常含 site.crt、intermediate.crt、root.crt)。

Lifetoon
Lifetoon

免费的AI漫画创作平台

下载

2、将站点证书与中间证书合并为一个文件:cat site.crt intermediate.crt > fullchain.pem

3、在 Nginx 中配置 ssl_certificate 指向 fullchain.pem;在 Apache 中使用 SSLCertificateFile 指向该文件。

四、指定 CA 证书路径供 PHP 使用

当系统 CA 存储缺失或过旧(如 Alpine Linux 容器、老旧 CentOS),PHP cURL 无法验证远程证书。可通过 CURLOPT_CAINFO 显式指定可信根证书路径。

1、下载 Mozilla CA 证书包:curl -o /etc/ssl/certs/ca-bundle.crt https://curl.se/ca/cacert.pem

2、在 PHP cURL 初始化后添加:curl_setopt($ch, CURLOPT_CAINFO, '/etc/ssl/certs/ca-bundle.crt');

3、确认该路径在 PHP 进程中具有读取权限,且文件格式为 PEM 编码

五、检查服务器时间与证书有效期关联性

SSL/TLS 协议严格依赖系统时间。若服务器本地时间偏差超过数分钟,即使证书本身有效,也会被判定为“尚未生效”或“已过期”。

1、执行:date 查看当前系统时间是否准确。

2、若时间异常,启用 NTP 同步:systemctl enable --now chronyd(RHEL/CentOS)或 systemctl enable --now systemd-timesyncd(Debian/Ubuntu)。

3、重启 Web 服务与 PHP-FPM 进程,使新时间生效于所有子进程。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

1640

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1074

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

978

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

948

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1396

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1226

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1437

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1302

2023.11.13

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

7

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 7.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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