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

猜你喜欢

转载自blog.csdn.net/u013202238/article/details/81557710
今日推荐