问题描述:

  最近一直在用github来写博客,但是今天发现github上的contributions记录并没有我的提交记录.

  经过一番百度和自行捣鼓发现了问题所在.

原因:

  最近实习,公司给配电脑.原来没有git,是用homebrew安装的,github上的仓库也是用新电脑来创建的,以及后续博客的提交也是.

  因为是mac并没有进行本地的任何配置,就直接用终端把本地文件push到仓库中去了.

  原因也就在这里.

  因为你本地的git默认的user.name和user.email并不是你的,而是本机.所以在此期间你的commit都是默认本机的.

  你可以用git config user.name / git config user.email 来查看自己的git所属

  查不出的结果应该是为空,因为你根本就没设置过.

  然后用git log查看一下commit记录.你会惊奇的发现虽然在往你的github仓库中push,但是用户名和邮箱却不是你github的,而是系统默认的pc用户.

  所以github贡献统计的根本就不是你的账户,就没有贡献小绿点咯.

解决办法:

  1.如果你只是想以后的commit记录,你只需要把当前本地git的user.name和user.email配置一下即可.

$ git config --global user.name “github’s Name”

$ git config --global user.email "github@xx.com"

  这里只是在git config 后边添加上了你要更改的内容即可,--global参数指的是全局,也就是你本地的所有仓库,如果不加就是单个仓库.

   修改好后,你以后的commit就是你的账户了,就能被统计贡献小绿点了.

  2.如果你不想浪费之前的commit贡献,需要把所有你用默认账户的commit都归为你真正的名下怎么办.

  我们需要修改所有的commit和push历史

git filter-branch -f --env-filter '
if [ "$GIT_AUTHOR_NAME" = "oldName" ]
then
export GIT_AUTHOR_NAME="newName"
export GIT_AUTHOR_EMAIL="newEmail"
fi
' HEAD git filter-branch -f --env-filter '
if [ "$GIT_COMMITTER_NAME" = "oldName" ]
then
export GIT_COMMITTER_NAME="newName"
export GIT_COMMITTER_EMAIL="newEmail"
fi
' HEAD

  这里的oldName我们可以通过git log来查看,其实这里只要修改GIT_COMMITTER就可以了.

  AUTHOR记录的是这次修改的作者信息,COMMITTER是这次提交的用户信息.

  注意两者区别,

    如果你自己写自己提交,那么两者都是你.

    有的项目有的人并没有commit权限,所以他需要修改完之后交给有权限的人提交,这样你是AUTHOR并不是COMMITTER 

  如果修改成功提示:Ref 'refs/heads/master' was rewritten.

   如果修改失败提示:Ref 'refs/heads/master' is unchanged.这里可能是因为你填写的oldName并没有找到.

   如果无差别把所有都改的话去掉if..fi

git filter-branch -f --env-filter "
GIT_AUTHOR_NAME='newName';
GIT_AUTHOR_EMAIL='newEmail';
GIT_COMMITTER_NAME='newName';
GIT_COMMITTER_EMAIL='newEmail'
" HEAD

  这样就全部改过来了.

注意:

  你这里将你本地git的账户和邮箱重新设置了,但是github并没有那么智能就能判断你是原来你系统默认的用户.

  也就是说你新配置的用户和你默认的被github识别成两个用户.

  这样你以后操作的时候commit 或者 push的时候有可能产生冲突.

  解决方法是

  1.使用强制push的方法:

  $ git push -u origin master -f
  这样会使远程修改丢失,一般是不可取的,尤其是多人协作开发的时候。

  我这里只是自己写的博客,所以就直切全部强制覆盖掉了.

  2.push前先将远程repository修改pull下来

  git pull origin master
  git push -u origin master

  3.若不想merge远程和本地修改,可以先创建新的分支:

  git branch [name]
  然后push

  git push -u origin [name]

效果图:

在使用默认的git用户修改的显示是这样的,nice是我的pc用户名

修改之后,

修改完之后刷新,我的贡献小绿点全部出来了.(小绿点是以账户邮箱为单位记录的,如果有多个邮箱,可以在信息里的email添加新邮箱就完事ok)

最后叮嘱:

  当我们换电脑使用git的时候,记得修改 git config user.name/user.email就不会出现这样的问题了.

【git】提交到github不显示贡献小绿点问题的解决的更多相关文章

  1. 使用git提交到github,每次都要输入用户名和密码的解决方法

    使用git提交文件到github,每次都要输入用户名和密码,操作起来很麻烦,以下方法可解决,记录以下. 原因:在clone 项目的时候,使用了 https方式,而不是ssh方式. 默认clone 方式 ...

  2. git提交后文件夹显示灰色无法打开的解决办法

    上传完本地文件到gitee线上后发现如下情况,文件夹显示为灰色并且无法访问. xxx@xxx 的灰色文件 问题原因 : 无法点击的灰色文件夹中含有 .git 文件 即在本地初始化的仓库(使用 git ...

  3. git 提交到github时不用每次都输入用户名,密码

    Permanently authenticating with Git repositories, Run following command to enable credential caching ...

  4. 使用git命令提交远程github仓库的时候提示"rejected"(拒绝)解决办法

    今天使用在自己笔记本本地磁盘上使用Git命令行执行"git push"然后输入github的用户名和密码之后,报如下错误: ![rejected] master->maste ...

  5. Git提交到github上

    1.本地创建一个目录redis [guosong@etch171 mars171 redis]# pwd /data1/guosong/code/redis [guosong@etch171 mars ...

  6. 本地项目文件通过git提交到GitHub上

    参考:https://blog.csdn.net/kongying19910218/article/details/50515834 步骤: 1.初始化git,假如我们要提交test文件夹下的所有目录 ...

  7. putty完全使用手册--多窗口---git提交---连接数据库--自动日志显示

    01 putty dev 192.168.3.38 02 cd /home/gongfu/tripb/cranedev02.1 git status git add git commit git pu ...

  8. github提交代码contributions不显示小绿块

    问题描述: 最近发现一个问题就是不管是提交新增的代码还是修改后提交的代码在github的contributions上都不显示贡献小绿块. 于是我在 github help 里面找到了答案: 官方链接如 ...

  9. 使用git提交代码到github,每次都要输入用户名和密码的解决方法

    自从使用git提交代码到github后,发现自己使用git的功力增长了不少,但也遇到不少问题.比如,使用git提交代码到github的时候,经常要求输入用户名和密码,类似这种: 网上有这么一种解决方法 ...

随机推荐

  1. 基于go手动写个转发代理服务

    由于公司经常需要异地办公,在调试的时候需要用到内网环境,因此手动写了个代理转发服务器給兄弟们用:socks5proxy. 选型上,语言上就选择了Go,简单清晰,转发协议选择了socks5. SOCKS ...

  2. qt——类大全

    qt类总结地址 http://www.kuqin.com/qtdocument/ QWidget.QDialog及QMainWindow的区别 QWidget类是所有用户界面对象的基类. 窗口部件是用 ...

  3. poj 2723 Get Luffy Out 2-SAT

    两个钥匙a,b是一对,隐含矛盾a->!b.b->!a 一个门上的两个钥匙a,b,隐含矛盾!a->b,!b->a(看数据不大,我是直接枚举水的,要打开当前门,没选a的话就一定要选 ...

  4. RDD的基础知识

    以下的这些分析都是基于spark2.1进行的 (一)什么是RDD A Resilient Distributed Dataset (RDD), the basic abstraction in Spa ...

  5. Django小项目web聊天

    WEBQQ的实现的几种方式 1.HTTP协议特点 首先这里要知道HTTP协议的特点:短链接.无状态! 在不考虑本地缓存的情况举例来说:咱们在连接博客园的时候,当tcp连接后,我会把我自己的http头发 ...

  6. 2.8 The Object Model -- Enumerables

    在Ember.js中,枚举是包含许多子对象的任何对象,并允许你使用Ember.Enumerable API和那些子对象一起工作.在大部分应用程序中最常见的可枚举是本地JS数组,Ember.js扩展到符 ...

  7. 4.4 Routing -- Specifying A Route's Model

    一.概述 应用程序中,templates被models支持.但是templates是如何知道它们应该显示哪个model呢? 例如,你有一个photos模板,它是如何知道它该呈现哪个model呢? 这就 ...

  8. hdu5106 数位dp

    这题说的是给了一个二进制数R , 计算出 在[0,R) 区间内的数, 二进制中有n个1 个和 n<=1000; R<2^1000, 这样 用dp[len][lee] 表示在第len位的时候 ...

  9. Hopper Disassembler v4 ( The macOS Disassembler, Decompiler and Debugger)

    Hopper Disassembler v4 ( The macOS Disassembler, Decompiler and Debugger) Reveal13 (UI) 两个好东西..不知道的自 ...

  10. Tomcat环境变量设置

    tomcat环境变量配置     CATALINA_HOME:D:\server\apache-tomcat-8.5.32 //安装目录      CATALINA_BASE:D:\server\ap ...