git常用命令詳解

@[toc]

1.本地git賬號和遠程github賬號關聯(lián)

  • 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倉庫關聯(lián)

  • 1.通過命令 git init 把這個目錄變成git可以管理的倉庫:git init
  • 2.把文件添加到版本庫中:git add .
  • 3.把文件提交到倉庫:git commit -m 'first commit'
  • 4.關聯(lián)到遠程庫:git remote add origin 你的遠程庫地址
  • 5.獲取遠程庫與本地同步合并:git pull --rebase origin master
  • 6.把本地庫的內容推送到遠程:git push -u origin master
  • 7.查看本地倉庫狀態(tài):git status
  • 8.查看遠程庫狀態(tài):git remote show origin
  • 9.查看日志:git log

3.分支相關

  • 1.查看本地分支:git branch
  • 2.查看遠程分支:git branch -r
  • 3.創(chuàng)建分支:git branch name
  • 4.切換分支:git checkout name
  • 5.創(chuàng)建+切換分支:git checkout -b name
  • 6.創(chuàng)建+切換+關聯(lián)遠程分支: 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.創(chuàng)建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遠程庫關聯(lián)的時候報錯 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命令清除一下相關的緩存內容,這樣文件將以未追蹤的形式出現(xiàn),然后再重新添加提交一下,gitignore文件里的規(guī)則就可以起作用了

回退操作
  • 撤銷本地所有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

發(fā)現(xiàn)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
  • 創(chuàng)建一個空的分支
    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 是什么意思

現(xiàn)在有這樣一種情形:
有一個叫做Joe的程序猿寫了一個游戲程序,而你可能要去改進它。并且Joe將他的代碼放在了GitHub倉庫上。

下面是你要做的事情

fork并且更新GitHub倉庫的圖表演示


image
  1. Fork他的倉庫:這是GitHub操作,這個操作會復制Joe的倉庫(包括文件,提交歷史,issues,和其余一些東西)。復制后的倉庫在你自己的GitHub帳號下。目前,你本地計算機對這個倉庫沒有任何操作。
  2. Clone你的倉庫:這是Git操作。使用該操作讓你發(fā)送"請給我發(fā)一份我倉庫的復制文件"的命令給GitHub。現(xiàn)在這個倉庫就會存儲在你本地計算機上。
  3. 更新某些文件:現(xiàn)在,你可以在任何程序或者環(huán)境下更新倉庫里的文件。
  4. 提交你的更改:這是Git操作。使用該操作讓你發(fā)送"記錄我的更改"的命令至GitHub。此操作只在你的本地計算機上完成。
  5. 將你的更改push到你的GitHub倉庫:這是Git操作。使用該操作讓你發(fā)送"這是我的修改"的信息給GitHub。Push操作不會自動完成,所以直到你做了push操作,GitHub才知道你的提交。
  6. 給Joe發(fā)送一個pull request:如果你認為Joe會接受你的修改,你就可以給他發(fā)送一個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
# 再次查看本地的遠程分支信息,這時已經(jīng)可以看到遠程分支已經(jīng)添加進去了
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倉庫,有沖突請繼續(xù)往下看
git push origin master
  • 處理沖突

這時我們可以點開vscode的Source Control(源代碼管理)就可以很方便的查看到?jīng)_突的文件,處理完沖突然后再次合并。

# 提交并注釋
git commit -m "upgrade"
# 這時執(zhí)行合并提示成功了
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參數(shù)表示:顯示出簽名詳細信息-keystore表示使用當前目錄中的debug.jks(或者格式為.keystore)簽名證書文件
-storepass XXXXXX表示Keystore密碼
-signedjar android_sign.apk表示簽名后生成的APK名稱
android.apk表示未簽名的APK Android軟件
-digestalg SHA1 -sigalg MD5withRSA:這就是必須加上的參數(shù),如果你是jdk 1.6也不受影響
key:需要換成你的簽名文件的別名

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

  • 一、 Git 命令初識 在正式介紹Git命令之前,先介紹一下Git 的基本命令和操作,對Git命令有一個總體的認識...
    子瘋zp閱讀 70,385評論 1 18
  • 自己的倉庫管理: git add <filename> 將文件添加到暫存區(qū)中 (其中git add.可以將當前目...
    我只要喝點果粒橙閱讀 267評論 0 0
  • 開始: 1) 遠程倉庫相關命令 檢出倉庫:$ git clone git://github.com/jquery/...
    草根老張閱讀 920評論 0 50
  • 分布式版本管理工具 git屬于分布式 svn集中式 git安裝 git初始化一個倉庫 其實就是創(chuàng)建了一個.git隱...
    SnowDragonYY閱讀 1,592評論 0 0
  • 本文針對初級用戶,從最簡單的講起,但是需要讀者對Git的基本用法有所了解。 Git是開源的分布式版本控制系統(tǒng),...
    Sachie閱讀 1,252評論 0 2

友情鏈接更多精彩內容