zoukankan      html  css  js  c++  java
  • Git修改提交历史中的作者及邮箱信息


    一、使用rebase

    如图,红圈中提交的用户名及邮箱是需要改的,则需要复制需要改的提交记录的上一个记录hashcode,在本例中就是a0a891a48f92b51201042fccbe61ed12646eda5e
    image

    git rebase -i a0a891a48f92b51201042fccbe61ed12646eda5e
    

    • 也可以用HEAD~步长的方式,但如果提交记录很久远的话,算步长就不太现实,所以更推荐hashcode写法
    git rebase -i HEAD~1
    
    • 如果整个仓库只有1次提交,即root提交,则需要用如下命令
    git rebase -i --root
    

    二、此时进入编辑界面,记录着commit的信息

    image

    三、修改需要修改的commit

    需要修改哪个commit就在行首将pick改为edit,在本例中则需要改第一行
    image

    四、保存退出

    wq保存退出之后会返回如下内容
    image

    五、修改用户名及邮箱

    git commit --amend --reset-author
    

    命令执行后会进入提交日志的编辑界面,我们仅需要修改用户名及邮箱,不需要修改提交日志信息,wq保存退出即可
    image

    接下来此次提交的作者及邮箱会被修改为--local级别的用户名及邮箱,若该级别没有设置,则会使用--global级别的用户名及邮箱

    • 如果不想使用已经设置好的用户名及邮箱的话,也可以手动指定用户名及邮箱:
    git commit --amend --author="otheruser <otheremail@qq.com>"
    

    六、结束rebase

    git rebase --continue
    

    再查看提交记录,可以看到提交的作者及邮箱已经改正了
    image

    七、同步到远程仓库上

    git push -f origin master
    


    尊重写作权利,转载请注明出处 ^_^
  • 相关阅读:
    RabbitMQ安装与配置
    在Web项目中使用shiro
    solr整合spring
    mycat
    SpringSession管理
    Nginx安装与配置(Nginx服务器和Tomcat服务器是不同的服务器)
    dubbo负载均衡与服务降级以及Zookeeper认证
    小笔记
    SpringMVC路径转发与重定向
    java-同步控制及不可变设置(只读访问)
  • 原文地址:https://www.cnblogs.com/convict/p/14897726.html
Copyright © 2011-2022 走看看