您好,欢迎访问宜昌市隼壹珍商贸有限公司
400 890 5375答案是手动或自动添加目标服务器的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 操作。