Git忽略大小写(重命名文件)的解决办法

 更新时间:2026年02月04日 09:14:55   作者:辰风沐阳  
作为一个使用 git 作为版本控制的程序员,相信各位都遇到过这种问题,文件名或目录名的大小写整错了,这是因为 git 默认不区分文件名的大小写,所以本文给大家介绍了Git忽略大小写(重命名文件)的解决办法,需要的朋友可以参考下

1. 场景描述

作为一个使用 git 作为版本控制的程序员,相信各位都遇到过这种问题,文件名或目录名的大小写整错了

场景描述

比如:想要创建一个文件 User.php,但是文件名打成了 user.php,并且已将 user.php 提交到了版本库

然后,你应该会将错误的 user.php 修改为正确 User.php,但是发现 git 没有监听到文件发生变化

问题原因

这是因为 git 默认不区分文件名的大小写,也就是对大小写不敏感,所以此时 git 并不认为文件发生变化了

我的解决办法

先尝试使用 git mv 命令从工作区和暂存区重命名文件,发现是不行的,继续尝试其他方法

$ git mv user.php User.php
fatal: destination exists, source=liang.php, destination=Liang.php

之前我遇到这种问题,会先修改其名称(不仅仅修改大小写),提交到版本库,然后再修改为正确的名称,再次提交

比如:将 user.php 修改为 user1.php 后提交到版本库,然后再修改为 User.php,再提交到版本库

但是,这种办法肯定不好的,为了解决这个问题不仅仅是多了两个提交记录,而且还要自己去找到大小写错误的文件

其实,git 提供了严格区分大小写的配置项,接下来我们学习一下这个配置,当修改了名称的大小写,让 git 自己去发现

2. 配置命令

查看当前是否忽略大小写配置,输出结果:true(忽略大小写,默认配置)、false(已经严格区分大小写)

git config --get core.ignorecase

全局设置,将忽略大小写关闭,也就是开启大小写敏感,从而能够正确识别文件名大小写的更改

git config --global core.ignorecase false

不过,有时从远程仓库拉取到本地时,当前项目的 git 配置可能默认就是忽略大小写(经测试 gitee 是这样的)

通过查看本地仓库配置文件内容,或者查看本地仓库配置都可以证实

# 查看本地仓库配置文件内容
cat .git/config
# 查看本地仓库配置中的忽略大小写配置
git config --local --list | grep ignorecase

因为项目配置优先级高于全局配置,所以此时全局配置开启大小写敏感已经失效,需要手动设置当前项目开启大小写敏感

git config core.ignorecase false

3. 流程分析

开启大小写敏感后,修改文件名,git 能监听到文件变化了,直接提交是不是就可以将文件重命名成功了呢 ?

将 user.php 重命名为 User.php,查看状态可以发现

  • user.php 没有提示被删除,所以它还在被 git 管理追踪
  • User.php 是一个没有追踪的文件,需要将它提交到暂存区
On branch master
Your branch is up to date with 'origin/master'.

Untracked files:
  (use "git add <file>..." to include in what will be committed)
	User.php

nothing added to commit but untracked files present (use "git add" to track)

如果直接将 User.php 提交到版本库,会怎么样 ?你会发现远程库既有 user.php,又有 User.php(此时你是不是很无语)

git add User.php
git commit -m '将 user.php 修改为 User.php'
git push

因为远程库有两个相同名称的文件(只是大小写不同),别人 clone 仓库时,能拉取成功,但是会有以下提示

warning: the following paths have collided (e.g. case-sensitive paths
on a case-insensitive filesystem) and only one from the same
colliding group is in the working tree:

  'User.php'
  'user.php'

所以,我们需要将远程库的无用的 user.php 删除掉。然后,别人重新 clone 就可以得到正确的 User.php 了

git rm --cached user.php
git commit -m '删除暂存区中的 user.php'
git push

4. 最佳实践

首先,关闭忽略大小写,也就是开启大小写敏感,修改文件名称时让 git 可以追踪的到

git config core.ignorecase false

手动修改文件名称,然后从暂存区删除旧文件,将新文件提交到暂存区

git rm --cached user.php
git add User.php

此时查看状态,也可以发现当前确实是一个重命名的操作

On branch master
Your branch is up to date with 'origin/master'.

Changes to be committed:
  (use "git restore --staged <file>..." to unstage)
	renamed:    user.php -> User.php

然后正常提交并推送到远程库即可

git commit -m 'renamed: user.php -> User.php'
git push

以上就是Git忽略大小写(重命名文件)的解决办法的详细内容,更多关于Git忽略大小写(重命名文件)的资料请关注脚本之家其它相关文章!

相关文章

  • 级联分类器算法原理解析

    级联分类器算法原理解析

    这篇文章主要为大家介绍了级联分类器算法的原理解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • Postman 使用指南及小技巧

    Postman 使用指南及小技巧

    Postman 简化了构建 API 的每个步骤,并简化了协作,这样就可以更快地创建 API。接下来通过本文给大家介绍Postman 使用指南及小技巧,感兴趣的朋友跟随小编一起看看吧
    2021-12-12
  • 详解https 加密完整过程

    详解https 加密完整过程

    这篇文章主要介绍了详解https 加密完整过程的相关资料,这里主要说名https加密及通信的方法,需要的朋友可以参考下
    2017-07-07
  • 深入解析Git中rebase与merge的核心区别及最佳实践

    深入解析Git中rebase与merge的核心区别及最佳实践

    在日常开发中,Git 是不可或缺的版本控制工具,本文将深入解析Git中rebase与merge的核心区别及最佳实践,从而带你彻底搞懂这两个命令,并学会如何科学地管理 Git 分支
    2026-05-05
  • 使用Postman测试需要授权的接口问题

    使用Postman测试需要授权的接口问题

    Postman是一款免费的http模拟请求工具,常用来测试开发接口。实际场景中,很多接口是需要授权才能使用,这篇文章主要介绍了用Postman测试需要授权的接口,需要的朋友可以参考下
    2022-06-06
  • 怎样写commit log记录及如何提交有哪些约定

    怎样写commit log记录及如何提交有哪些约定

    这篇文章主要为大家介绍了怎样写commit log记录以及及如何提交有哪些约定,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • Git代码库大文件历史记录的清理方法

    Git代码库大文件历史记录的清理方法

    在日常开发中,我们可能会不小心将一些大文件(如二进制文件、大型资源文件等)提交到Git仓库中,即使后来删除了这些文件,它们依然存在于 Git 的历史记录中,导致 .git 目录变得非常庞大,本文将介绍如何分析 Git 仓库的占用情况,并使用工具清理历史记录中的大文件
    2025-11-11
  • 低版本VS项目在VS2019无法正常编译的问题

    低版本VS项目在VS2019无法正常编译的问题

    这篇文章主要介绍了低版本VS项目在VS2019无法正常编译的问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • zend stdio8.0 快捷键汇总集合

    zend stdio8.0 快捷键汇总集合

    接下来小编就为大家介绍一下在Zend Stdio 8.0版本中的快捷键汇总。需要的朋友可以过来参考下,希望对大家有所帮助
    2013-10-10
  • 使用SSH协议解决Git推送失败问题的具体操作方法

    使用SSH协议解决Git推送失败问题的具体操作方法

    在日常开发中,我们常常会遇到 Git 推送失败的问题,尤其是在初次配置远程仓库或网络环境受限的情况下,本文将详细介绍如何通过配置 SSH 协议解决 Git 推送失败问题,需要的朋友可以参考下
    2026-01-01

最新评论