git初始化后,我添加并提交了一些文件,做了一些修改,添加并提交。设置git守护进程(在WinXP上的Cygwin下运行)并克隆一次存储库。 现在,我得到这个错误与克隆的存储库:

$ git status
error: bad index file sha1 signature
fatal: index file corrupt

除了获得一个新的存储库副本之外,还有什么方法可以修复这个问题吗?


当前回答

rm -f .git/index
git reset

更多信息请访问https://www.chris-shaw.com/blog/quick-fix-for-git-corrupt-index

其他回答

现有的答案都不适合我。

我使用的是工作树,所以没有。git文件夹。

你需要回到你的主回购。其中,删除。git/worktrees/<name_of_tree>/index

然后按照其他答案运行git reset。

在Windows PowerShell上,应该是这样

rm -Force .git/index
git reset

我做了一个简单的魔术。我克隆回购到一个新的文件夹。从新文件夹复制。git文件夹到repo的旧文件夹,替换。git。

你可能不小心在你的项目根目录上用sed损坏了.git/index文件(可能是重构?)

sed -ri -e "s/$SEACHPATTERN/$REPLACEMENTTEXT/g" $(grep -Elr "$SEARCHPATERN" "$PROJECTROOT")

为了在将来避免这种情况,只需忽略grep/sed的二进制文件:

sed -ri -e "s/$SEACHPATTERN/$REPLACEMENTTEXT/g" $(grep -Elr --binary-files=without-match "$SEARCHPATERN" "$PROJECTROOT")

由于上述解决方案给我带来了持续的问题,我使用了这个乏味的解决方案:

在其他地方克隆一个新的副本 将新的.git目录复制到包含我想提交的更改的(损坏的)repo中

成功了。顺便说一句,我做了一个sed项目根@hobs猜测。我吸取教训了。