答案是手动或自动添加目标服务器的SSH主机密钥。首先通过ssh git@github.com手动连接并接受主机密钥,或在自动化环境中使用ssh-keyscan github.com >> ~/.ssh/known_hosts预加载指纹,也可临时改用HTTPS协议composer config -g github-protocols https,同时确保SSH密钥已正确配置并添加至Git平台账户。

当使用 Composer 安装依赖或从私有 Git 仓库拉取代码时,如果遇到 Host key verification failed 的 SSH 错误,通常是因为 Composer 在执行 git clone 操作时无法验证目标服务器的 SSH 主机密钥。系统出于安全考虑阻止连接,导致操作失败。
这个问题与 Composer 本身无关,而是底层 git 命令通过 SSH 协议连接远程服务器(如 GitHub、GitLab)时触发的安全机制。以下是几种有效的解决方法:
最直接的方式是手动通过 SSH 连接一次目标 Git 服务器,接受主机密钥:
ssh git@github.com
或如果是 GitLab:
ssh git@gitlab.com
~/.ssh/known_hosts 文件中,后续 git 和 Composer 就不会再报错。在自动化部署或 Docker 构建中,不能手动确认。可以预先用命令自动添加主机指纹:
例如添加 GitHub:
ssh-keyscan github.com >> ~/.ssh/known_hosts
添加 GitLab:
ssh-keyscan gitlab.com >> ~/.ssh/known_hosts
如果你不需要使用 SSH 认证,可让 Composer 改用 HTTPS 协议拉取包:
执行命令:
composer config -g github-protocols https
确保你的 SSH 公钥已添加到对应 Git 平台账户中:
ls ~/.ssh/id_rsa 或 id_ed25519
ssh -T git@github.com
基本上就这些。重点是让系统信任目标主机的 SSH 指纹,Composer 才能顺利完成 git 操作。
以上就是Composer如何解决Host key verification failed SSH错误的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号