系上一篇后,还在被 GitHub 账号折腾,遂记录问题。
问题背景:之前本地关联过一个GitHub账号,每次git push都用这个原始账号。最近在做不同的项目作业,需要使用其他GitHub账号。
在进行了本地关联多个GitHub账号之后,发现明明跟原始账号无关的仓库,提交的commit还是原始GitHub账号,没有改变。
需求:1)改变项目的提交账号,即之后commit账号都是正确的;2)修改之前已提交commit的账号到正确的账号下。
GPT说这个需求是可行的,该操作叫重写 Git 历史 。
改完后,那些 commit 的内容、提交时间都不会变,但它们的 commit SHA 会变。
0. 一些前置操作
先确认当前分支:
bash
git branch --show-current
留个备份,防止手滑:
bash
git branch backup-before-author-fix
查看并确认当前 commit 作者信息:
bash
git log --pretty=format:"%h | %an | %ae | %s" --max-count=30
1. 先设置以后新 commit 的账号
注意,这里不要加 --global:
bash
git config user.name "你的新GitHub用户名"
git config user.email "你的新GitHub邮箱"
确认是否修改成功:
bash
git config --local user.name
git config --local user.email
2. 批量修改旧 commits 的作者
这一步建议用 Git Bash ,不要用 PowerShell,减少引号问题。
在项目文件夹里右键Open Git Bash here,输入以下命令:
bash
git filter-branch --env-filter '
OLD_EMAIL="你的旧GitHub邮箱"
CORRECT_NAME="你的新GitHub用户名"
CORRECT_EMAIL="你的新GitHub邮箱"
if [ "$GIT_COMMITTER_EMAIL" = "$OLD_EMAIL" ]; then
export GIT_COMMITTER_NAME="$CORRECT_NAME"
export GIT_COMMITTER_EMAIL="$CORRECT_EMAIL"
fi
if [ "$GIT_AUTHOR_EMAIL" = "$OLD_EMAIL" ]; then
export GIT_AUTHOR_NAME="$CORRECT_NAME"
export GIT_AUTHOR_EMAIL="$CORRECT_EMAIL"
fi
' HEAD
这段命令的意思:当前分支历史里,凡是
author/committer email等于原始旧邮箱的 commit,全部改成新账号信息。
检查是否改成功:
bash
git log --pretty=format:"%h | %an | %ae | %s" --max-count=30
3. 强制更新远程分支
因为改了历史,普通 push 会失败:
bash
git push --force-with-lease origin [当前分支名/main]
如果当前工作区还有写一半的代码,先 stash:
bash
git stash push -u -m "temp unfinished work"
再做上面的作者修改。
改完并 push 后,再恢复:
bash
git stash pop
参考教程来自ChatGPT