0

0

composer 提示 "git config source.xxx.git http" 错误怎么办?

穿越時空

穿越時空

发布时间:2025-11-23 18:03:06

|

865人浏览过

|

来源于php中文网

原创

当Composer因Git配置问题无法安装包时,需调整Git协议或使用镜像源。1. 检查并修正Git全局配置,删除错误的insteadOf规则;2. 设置git config --global url."https://".insteadOf git://,避免防火墙拦截;3. 配置Composer使用国内镜像如阿里云,并同步设置Git镜像地址;4. 在composer.json中为特定包指定HTTPS仓库地址或全局替换SSH为HTTPS;5. 可临时设置preferred-install为dist,优先下载zip包避免调用Git。核心是确保Git能通过HTTPS访问仓库并配合镜像加速。

composer 提示 \

当你在使用 Composer 安装或更新包时,遇到提示类似 "git config source.xxx.git http" 的错误,通常是因为 Composer 尝试通过 Git 克隆某个依赖包,但当前环境没有配置正确的 Git 源地址,或者 Git 配置被限制了 HTTP/HTTPS 的使用。

这个问题常见于企业内网、GitHub 被屏蔽或 Composer 镜像未完全生效的场景。下面是几种有效的解决方法

1. 检查并修改 Git 的全局配置

Composer 在拉取私有或公开 Git 仓库时会调用系统 Git。如果 Git 被配置为强制使用 HTTPS 或 SSH,而网络不通,就会报错。

查看当前 Git 配置是否有强制规则:

git config --global --get url."https://".insteadOf
git config --global --get url."git://".insteadOf

如果你看到类似:

git config --global url."https://github.com/".insteadOf "git@github.com:"

这表示 Git 正在尝试替换协议,但可能目标地址不可访问。你可以删除或修正它:

  • 删除错误配置:
    git config --global --unset url."https://github.com/".insteadOf
  • 改为使用镜像地址(如国内可用):
    git config --global url."https://mirrors.tencent.com/git/".insteadOf "https://github.com/"

2. 让 Composer 使用 HTTPS 替代 Git 协议

Git 默认使用 git:// 协议,该协议使用 9418 端口,常被防火墙拦截。

设置 Git 使用 HTTPS 代替:

git config --global url."https://".insteadOf git://

这样所有 git:// 开头的地址都会自动转为 https://,提高成功率。

来福FM
来福FM

来福 - 你的私人AI电台

下载

3. 修改 Composer 配置使用镜像源

如果你在中国大陆,建议使用 Composer 镜像加速,并确保 Git 仓库也能走镜像。

设置 Composer 镜像(例如阿里云):

composer config -g repo.packagist composer https://mirrors.aliyun.com/composer/

同时确保 Git 可以访问镜像站点:

git config --global url."https://mirrors.aliyun.com/git/".insteadOf "https://github.com/"

4. 强制使用 HTTPS 拉取特定包

某些包在 composer.json 中定义的是 git@github.com:xxx 的 SSH 地址,若 SSH 不通也会失败。

可以在项目根目录的 composer.json 中添加仓库配置,改用 HTTPS:

"repositories": [
    {
        "type": "vcs",
        "url": "https://github.com/xxx/package-name"
    }
]

或全局设置 Git 替换:

git config --global url."https://github.com/".insteadOf "git@github.com:"

5. 临时关闭 Git 外部命令(慎用)

如果只是想快速跳过 Git 问题,可以让 Composer 不调用外部 Git:
composer config --global preferred-install dist

这会让 Composer 优先下载打包好的 zip 包,而不是通过 Git 克隆,适合生产环境。

基本上就这些。关键是让 Git 能正常访问远程仓库,要么修复网络,要么做协议替换,再配合 Composer 镜像,问题就能解决。不复杂但容易忽略配置细节。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

149

2023.12.25

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

412

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

533

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

自建git服务器
自建git服务器

git服务器是目前流行的分布式版本控制系统之一,可以让多人协同开发同一个项目。本专题为大家提供自建git服务器相关的各种文章、以及下载和课程。

639

2023.07.05

git和svn的区别
git和svn的区别

git和svn的区别:1、定义不同;2、模型类型不同;3、存储单元不同;4、是否拥有全局版本号;5、内容完整性不同;6、版本库不同;7、克隆目录速度不同;8、分支不同。php中文网为大家带来了git和svn的相关知识、以及相关文章等内容。

526

2023.07.06

git撤销提交的commit
git撤销提交的commit

Git是一个强大的版本控制系统,它提供了很多功能帮助开发人员有效地管理和控制代码的变更,本专题为大家提供git 撤销提交的commit相关的各种文章内容,供大家免费下载体验。

264

2023.07.24

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

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

43

2026.01.16

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.3万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

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

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