本文主要是介绍git 修改历史提交的用户名和邮箱,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
第一步clone 下git待修改的创库,如果已经有了跳过
第二步执行如下脚本
#!/bin/sh
git filter-branch --env-filter '
OLD_EMAIL="老的邮箱"
CORRECT_NAME="新用户名"
CORRECT_EMAIL="新邮箱"
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
' --tag-name-filter cat -- --branches --tags
第三步提交修改
git push --force --tags origin 'refs/heads/*'
但是当你再次执行脚本,想修改其他提交的姓名时会发现git抛出了异常,
Cannot create a new backup.
A previous backup already exists in refs/original/
Force overwriting the backup with -f
出现这一句说明之前曾经执行过 git filter-branch,然后在 refs/original/ 有一个备份,这个时候只要删掉那个备份即可,删除备份命令为 git update-ref -d refs/original/refs/heads/master
,或执行 $ git filter-branch -f --tree-filter -f 'rm -f test' -- --all
这篇关于git 修改历史提交的用户名和邮箱的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!