【发布时间】:2021-04-11 04:01:32
【问题描述】:
我最近在 GitHub 上更改了我的用户名,另外我想在提交时隐藏我的真实电子邮件并保留提交历史。假设我没有任何贡献者,所以所有提交都是我的。找到了一些使用 git filter-branch 的建议,但是运行它时我收到了一个警告,它可能会损坏我的存储库。有其他选择吗?
【问题讨论】:
我最近在 GitHub 上更改了我的用户名,另外我想在提交时隐藏我的真实电子邮件并保留提交历史。假设我没有任何贡献者,所以所有提交都是我的。找到了一些使用 git filter-branch 的建议,但是运行它时我收到了一个警告,它可能会损坏我的存储库。有其他选择吗?
【问题讨论】:
因此,如果不需要或在任何地方都没有引用原始哈希,并且只需要更新作者姓名/电子邮件,那么只需两个简单的步骤即可。
请注意,它是不可逆的,因此请务必备份。
git config --global user.name "FIRST_NAME LAST_NAME"
git config --global user.email "MY_EMAIL@SOME_DOMAIN.com"
跳过--global 以获取特定于存储库的用户名/电子邮件配置。
git rebase -i --rebase-merges --root --exec 'GIT_COMMITTER_DATE="$(git log -n 1 --format=%aD)" git commit --amend --reset-author --no-edit --date="$(git log -n 1 --format=%aD)"'
编辑器将打开所有提交的列表和将在每次提交时执行的命令。这里不需要做任何事情,只需保存并退出。 之后将应用更改。
所以它的基本作用是从第一次提交开始以交互模式运行 re-base。对于每个提交,它获取原始提交的日期,设置GIT_COMMITTER_DATE(对 GitHub 很重要)和时间戳(将显示在git log 中),重置提交的作者,并修改更改。然后进入下一个提交。就是这样,现在你只需要强制推送更改以更新 GitHub 存储库。
git push -f
【讨论】: