0

0

composer如何解决由于OpenSSL版本过旧导致的连接失败_composer安全指南【实战】

穿越時空

穿越時空

发布时间:2026-01-17 09:16:02

|

953人浏览过

|

来源于php中文网

原创

Composer SSL错误通常因OpenSSL过旧导致,解决步骤包括:一、升级系统OpenSSL并重编PHP;二、配置Composer使用更新的CA证书包;三、仅调试时临时禁用TLS验证;四、切换国内镜像并启用兼容模式;五、用Docker封装新版OpenSSL环境。

composer如何解决由于openssl版本过旧导致的连接失败_composer安全指南【实战】

如果您在使用 Composer 安装或更新依赖时遇到 SSL 连接失败、证书验证错误或 “cURL error 60” 等提示,则很可能是系统中 OpenSSL 版本过旧,无法支持现代 TLS 协议(如 TLS 1.2/1.3)或无法验证 Packagist.org 等源使用的证书链。以下是解决此问题的步骤:

一、升级系统 OpenSSL 并重新编译 PHP

OpenSSL 是 PHP cURL 和 stream 扩展底层依赖的加密库,旧版 OpenSSL(如 1.0.1 或更早)已停止维护,不支持 SNI 或现代证书签名算法,导致无法与 Packagist HTTPS 接口建立安全连接。升级 OpenSSL 后需确保 PHP 重新链接到新版库。

1、检查当前 OpenSSL 版本:openssl version -a

2、检查 PHP 使用的 OpenSSL 版本:php -r "print_r(openssl_get_cipher_methods());" 并确认 php --ri openssl 中显示的版本号

3、在 Ubuntu/Debian 上执行:sudo apt update && sudo apt install -y openssl libssl-dev

4、在 CentOS/RHEL 7+ 上执行:sudo yum install -y openssl-devel 或使用 dnf install -y openssl-devel

5、若 PHP 为源码编译安装,进入 PHP 源码目录后运行:make clean && ./configure --with-openssl=/usr --with-curl --with-zlib && make && sudo make install

二、配置 Composer 使用替代 CA 证书包

Composer 默认依赖系统 CA 证书路径,但旧系统可能缺少 Let’s Encrypt ISRG Root X1 等新根证书。可显式指定一个更新的证书包路径,绕过系统自带证书限制。

1、下载最新 Mozilla CA 包:curl -sS https://curl.se/ca/cacert.pem -o /usr/local/share/ca-certificates/composer-cacert.pem

2、更新系统证书存储(Ubuntu/Debian):sudo cp /usr/local/share/ca-certificates/composer-cacert.pem /usr/share/ca-certificates/ && sudo update-ca-certificates

3、为 Composer 单独设置证书路径:composer config -g cafile /usr/local/share/ca-certificates/composer-cacert.pem

4、验证配置是否生效:composer config -g cafile 应输出对应路径

三、临时禁用 TLS 验证(仅限调试环境)

该方法绕过证书校验,**绝不适用于生产环境或含敏感凭证的项目**,仅用于快速定位是否为证书验证环节引发的连接失败。

1、全局禁用 SSL 验证:composer config -g secure-http false

来福FM
来福FM

来福 - 你的私人AI电台

下载

2、强制使用 HTTP 协议源(风险极高):composer config -g repo.packagist.org.url http://packagist.org

3、清除配置缓存:composer clear-cache

4、执行测试命令:composer diagnose 应不再报 SSL 相关错误

四、切换至国内镜像并启用 TLS 兼容模式

部分国内镜像(如阿里云、腾讯云)提供针对旧 OpenSSL 的兼容接口,其 Nginx 配置保留 TLS 1.0/1.1 支持,并采用较宽松的证书链策略,可作为过渡方案。

1、设置阿里云镜像源:composer config -g repo.packagist.org.url https://mirrors.aliyun.com/composer/

2、禁用证书域名验证(非禁用全部验证):export COMPOSER_CAFILE=/dev/null

3、执行更新命令前重载环境变量:source ~/.bashrc 或直接在当前 shell 运行 export 命令

4、运行诊断:composer diagnose -v 观察是否仍出现 “unable to verify the first certificate”

五、使用 Docker 封装兼容运行环境

当宿主机 OpenSSL 无法升级(如受限于老旧企业 OS),可通过官方 PHP Docker 镜像启动带新版 OpenSSL 的 Composer 环境,完全隔离系统依赖。

1、拉取带 OpenSSL 3.0+ 的 PHP 镜像:docker pull php:8.2-cli

2、创建本地 composer.json 映射目录:mkdir -p ~/my-project && cd ~/my-project

3、在项目目录内运行容器化 Composer:docker run --rm -it -v $(pwd):/app -w /app php:8.2-cli sh -c "curl -sS https://getcomposer.org/installer | php && php composer.phar install"

4、确认依赖正确解析:docker run --rm -v $(pwd):/app -w /app php:8.2-cli php composer.phar show --platform

相关专题

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

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

2602

2023.09.01

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

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

1628

2023.10.11

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

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

1510

2023.10.11

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

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

952

2023.10.23

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

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

1417

2023.10.23

html怎么上传
html怎么上传

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

1234

2023.11.03

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

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

1447

2023.11.09

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

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

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

41

2026.01.16

热门下载

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

精品课程

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

共137课时 | 8.7万人学习

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

共6课时 | 7.3万人学习

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

共13课时 | 0.9万人学习

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

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