git常用命令详解

@[toc]

1.本地git账号和远程github账号关联

  • 1.设置本地git的账号的用户名:git config --global user.name "mxdl"
  • 2.设置本地git账号的邮箱:git config --global user.email "mxdl@qq.com"
  • 3.生成git密钥文件:ssh-keygen -t rsa -C "mxdl@qq.com"
  • 4.进入C:\用户\xxx.ssh文件夹 将id_rsa.pub文件里面的秘钥添加到github上

由于本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以必须要让github仓库认证你SSH key,在此之前,必须要生成SSH key本地有更新,上传到github仓库

  • 查看本地账号用户名:git config user.name
  • 查看本地账号的邮箱:git config user.email

2.本地git仓库和远程github仓库关联

  • 1.通过命令 git init 把这个目录变成git可以管理的仓库:git init
  • 2.把文件添加到版本库中:git add .
  • 3.把文件提交到仓库:git commit -m 'first commit'
  • 4.关联到远程库:git remote add origin 你的远程库地址
  • 5.获取远程库与本地同步合并:git pull --rebase origin master
  • 6.把本地库的内容推送到远程:git push -u origin master
  • 7.查看本地仓库状态:git status
  • 8.查看远程库状态:git remote show origin
  • 9.查看日志:git log

3.分支相关

  • 1.查看本地分支:git branch
  • 2.查看远程分支:git branch -r
  • 3.创建分支:git branch name
  • 4.切换分支:git checkout name
  • 5.创建+切换分支:git checkout -b name
  • 6.创建+切换+关联远程分支: git checkout -b name origin/name
  • 7.合并分支:git merge name
  • 8.修改本地分支名称: git branch -m old_name new_name
  • 9.提交到远程分支:git push origin new_name
  • 10.克隆远程仓库:git clone https://www.github.com/geduo83/FlyTour
  • 11.克隆远程分支:git clone -b 2.0.0 https://www.github.com/geduo83/FlyTour
  • 12.删除本地分支:git branch -d name
  • 13.删除远程分支 :git push --delete origin name
  • 14 查看远程仓库地址:git remote -v

4.TAG相关

  • 1.查看tag :git tag
  • 2.创建tag:git tag tagname
  • 3.推送到远程tag :git push origin tagname
  • 4.删除本地tag:git tag -d tagnme
  • 5.删除远程tag:git push origin :refs/tags/tagname【先删除本地tag】
  • 6.删除远程tag:git push --delete origin tagname
  • 7.列出所有的分支和tag:git ls-remote

5.常见问题

Please enter a commit message to explain

.git中Please enter a commit message to explain why this merge is necessary.
Please enter a commit message to explain why this merge is necessary.
请输入提交消息来解释为什么这种合并是必要的


在这里插入图片描述

git 在pull或者合并分支的时候有时会遇到这个界面。可以不管(直接下面3,4步),如果要输入解释的话就需要:

  • 1 按键盘字母 i 进入insert模式
  • 2 修改最上面那行黄色合并信息,可以不修改
  • 3 按键盘左上角"Esc"
  • 4 输入":wq",注意是冒号+wq,按回车键即可
git remote add origin远程库关联的时候报错 fatal: remote origin already exists.解决方法
  • 1 先输入 git remote rm origin
  • 2 再输入 git remote add origin
gitignore不起作用的解决办法

git rm -r --cached .
git add .
git commit -m 'update .gitignore**

使用rm命令清除一下相关的缓存内容,这样文件将以未追踪的形式出现,然后再重新添加提交一下,gitignore文件里的规则就可以起作用了

回退操作
  • 撤销本地所有add操作:
    git reset HEAD .

  • 撤销本地的commit操作
    git reset --hard commit_id

  • 回滚到合并之前
    git merge --abort

git pull 失败 ,提示:fatal: refusing to merge unrelated histories

其实这个问题是因为 两个 根本不相干的 git 库,一个是本地库,一个是远端库, 然后本地要去推送到远端, 远端觉得这个本地库跟自己不相干, 所以告知无法合并

方法1: 是 从远端库拉下来代码 , 本地要加入的代码放到远端库下载到本地的库, 然后提交上去 , 因为这样的话, 你基于的库就是远端的库, 这是一次update了

方法2:git pull origin master --allow-unrelated-histories
后面加上 --allow-unrelated-histories , 把两段不相干的 分支进行强行合并

使用 git config --global user.name xxx的时候报错user.name has multiple values
core.symlinks=false
core.autocrlf=true
core.fscache=true
color.diff=auto
color.status=auto
color.branch=auto
color.interactive=true
help.format=html
rebase.autosquash=true
http.sslbackend=openssl
http.sslcainfo=C:/Program Files/Git/mingw64/ssl/certs/ca-bundle.crt
credential.helper=manager
user.email=geduo_83@163.com
user.name=geduo_83
user.name=“xb1
user.name=“xb1
user.naemail=xb1

发现user.name有多个值

然后我尝试着用,成功了
git config --global --replace-all user.email "输入你的邮箱" git config --global --replace-all user.name "输入你的用户名"

  • 删除多余的user键
git config --global --unset user.naemail
git remote set-url origin git+ssh://git@github.com:xxx/xxx.git
  • 创建一个空的分支
    git checkout --orphan 新的分支名
    git rm -rf .
    git add .
    git commit -m "init commit"
  • 查看一个文件的修改日志
git log utils/http.js
  • 恢复一个文件的本地修改
git checkout utils/http.js
  • 恢复文件到某个指定的提交
git log --pretty=oneline
8e1d139ff7f6875be3d5a60c2245549ca6c953fc (HEAD -> master, origin/master, origin/HEAD) 更新任务详单的修改面板问题
620be0ea945167d0578933c598f471d9bb256045 任务进展更新
f1742c32c03bffab354e525f7f0f9345241ec986 恢复进度表
a24897161559710694ddf3afb7d28132df380265 恢复进度表
$ git checkout 620b README.MD

6.GitHub的Fork 是什么意思

现在有这样一种情形:
有一个叫做Joe的程序猿写了一个游戏程序,而你可能要去改进它。并且Joe将他的代码放在了GitHub仓库上。

下面是你要做的事情

fork并且更新GitHub仓库的图表演示


image
  1. Fork他的仓库:这是GitHub操作,这个操作会复制Joe的仓库(包括文件,提交历史,issues,和其余一些东西)。复制后的仓库在你自己的GitHub帐号下。目前,你本地计算机对这个仓库没有任何操作。
  2. Clone你的仓库:这是Git操作。使用该操作让你发送"请给我发一份我仓库的复制文件"的命令给GitHub。现在这个仓库就会存储在你本地计算机上。
  3. 更新某些文件:现在,你可以在任何程序或者环境下更新仓库里的文件。
  4. 提交你的更改:这是Git操作。使用该操作让你发送"记录我的更改"的命令至GitHub。此操作只在你的本地计算机上完成。
  5. 将你的更改push到你的GitHub仓库:这是Git操作。使用该操作让你发送"这是我的修改"的信息给GitHub。Push操作不会自动完成,所以直到你做了push操作,GitHub才知道你的提交。
  6. 给Joe发送一个pull request:如果你认为Joe会接受你的修改,你就可以给他发送一个pull request。这是GitHub操作,使用此操作可以帮助你和Joe交流你的修改,并且询问Joe是否愿意接受你的"pull request",当然,接不接受完全取决于他自己。
  7. 如果Joe接受了你的pull request,他将把那些修改拉到自己的仓库!


    image

7. 在github上fork项目如何同步并解决冲突

# 查看原有远程分支信息
git remote -v
# 添加源项目的远程分支并命名为upgrade,名称随意
git remote add upgrade https://github.com/origin/xxx.git
# 再次查看本地的远程分支信息,这时已经可以看到远程分支已经添加进去了
git remote -v
# 把upgrade的代码拉取到本地
git fetch upgrade
# 查看并选中dev(默认是选中master),或者其他你想合并的分支,只有一个master分支可以忽略
git branch
# *号就是选中的
> * master
> dev
git checkout -b dev
# 合并upgrade到我们自己的master分支
git merge upgrade/master
# 如果没有提示冲突,直接推送到github仓库,有冲突请继续往下看
git push origin master
  • 处理冲突

这时我们可以点开vscode的Source Control(源代码管理)就可以很方便的查看到冲突的文件,处理完冲突然后再次合并。

# 提交并注释
git commit -m "upgrade"
# 这时执行合并提示成功了
git merge upgrade/master
# 推送到github
git push origin master
拉取B仓库的新代码
$ git fetch upstream

将B新的部分合并到A的代码仓库中, 使A的代码仓库变成最新的代码.
$ git rebase upstream/master origin/master

8.git教程

https://www.liaoxuefeng.com/wiki/896043488029600/896067074338496

9.apk重新签名

jarsigner -verbose -keystore xxx.keystore -storepass xxxx -signedjar Yesway_v6.1.7_上 线190219_legu_01.apk -digestalg SHA1 -sigalg MD5withRSA Yesway_v6.1.7上线_190219_legu.apk xxx

运行以下命令行(你就可千万别换行了,我这是为了让你们更直观的看见,其实每一行是连在一起的,中间只是有个空格)

jarsigner -verbose -keystore debug.jks
-storepass XXXXXX
-signedjar android_sign.apk
-digestalg SHA1 -sigalg MD5withRSA android.apk
key

-jarsigner是Java的签名工具-verbose参数表示:显示出签名详细信息-keystore表示使用当前目录中的debug.jks(或者格式为.keystore)签名证书文件
-storepass XXXXXX表示Keystore密码
-signedjar android_sign.apk表示签名后生成的APK名称
android.apk表示未签名的APK Android软件
-digestalg SHA1 -sigalg MD5withRSA:这就是必须加上的参数,如果你是jdk 1.6也不受影响
key:需要换成你的签名文件的别名

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容

  • 一、 Git 命令初识 在正式介绍Git命令之前,先介绍一下Git 的基本命令和操作,对Git命令有一个总体的认识...
    子疯zp阅读 69,751评论 1 18
  • 自己的仓库管理: git add <filename> 将文件添加到暂存区中 (其中git add.可以将当前目...
    我只要喝点果粒橙阅读 187评论 0 0
  • 开始: 1) 远程仓库相关命令 检出仓库:$ git clone git://github.com/jquery/...
    草根老张阅读 840评论 0 50
  • 分布式版本管理工具 git属于分布式 svn集中式 git安装 git初始化一个仓库 其实就是创建了一个.git隐...
    SnowDragonYY阅读 1,499评论 0 0
  • 本文针对初级用户,从最简单的讲起,但是需要读者对Git的基本用法有所了解。 Git是开源的分布式版本控制系统,...
    Sachie阅读 1,137评论 0 2