從0開始學習 GitHub 系列之「向GitHub 提交代碼」
之前的這篇文章「從0開始學習 GitHub 系列之「Git速成」」相信大家都已經對 Git 的基本操作熟悉了,但是這篇文章只介紹了對本地 Git 倉庫的基本操作,今天我就來介紹下如何跟遠程倉庫一起協作,教你們向 GitHub 上提交你們的第一行代碼!
1. SSH
你擁有了一個 GitHub 賬號之後,就可以自由的 clone 或者下載其他項目,也可以創建自己的項目,但是你沒法提交代碼。仔細想想也知道,肯定不可能隨意就能提交代碼的,如果隨意可以提交代碼,那麼 GitHub 上的項目豈不亂了套了,所以提交代碼之前一定是需要某種授權的,而 GitHub 上一般都是基於 SSH 授權的。
那麼什麼是 SSH 呢?
簡單點說,SSH是一種網路協議,用於計算機之間的加密登錄。目前是每一台 Linux 電腦的標準配置。而大多數 Git 伺服器都會選擇使用 SSH 公鑰來進行授權,所以想要在 GitHub 提交代碼的第一步就是要先添加 SSH key 配置。
2. 生成SSH key
Linux 與 Mac 都是默認安裝了 SSH ,而 Windows 系統安裝了 Git Bash 應該也是帶了 SSH 的。大家可以在終端(win下在 Git Bash 里)輸入 ssh 如果出現以下提示證明你本機已經安裝 SSH, 否則請搜索自行安裝下。
緊接著輸入 ssh-keygen -t rsa ,什麼意思呢?就是指定 rsa 演算法生成密鑰,接著連續三個回車鍵(不需要輸入密碼),然後就會生成兩個文件 id_rsa 和 id_rsa.pub ,而 id_rsa 是密鑰,id_rsa.pub 就是公鑰。這兩文件默認分別在如下目錄里生成:
Linux/Mac 系統 在 ~/.ssh 下,win系統在 /c/Documents and Settings/username/.ssh 下,都是隱藏文件,相信你們有辦法查看的。
接下來要做的是把 id_rsa.pub 的內容添加到 GitHub 上,這樣你本地的 id_rsa 密鑰跟 GitHub 上的 id_rsa.pub 公鑰進行配對,授權成功才可以提交代碼。
3. GitHub 上添加 SSH key
第一步先在 GitHub 上的設置頁面,點擊最左側 SSH and GPG keys :
然後點擊右上角的 New SSH key 按鈕:
需要做的只是在 Key 那欄把 id_rsa.pub 公鑰文件里的內容複製粘貼進去就可以了(上述示例為了安全粘貼的公鑰是無效的),Title 那欄不需要填寫,點擊 Add SSH key 按鈕就ok了。
這裡提醒下,怎麼查看 id_rsa.pub 文件的內容?
Linux/Mac 用戶執行以下命令:
cd ~/.ssh
cat id_rsa.pub
Windows用戶,設置顯示隱藏文件,可以使用 EditPlus 或者 Sublime 打開複製就行了。
SSH key 添加成功之後,輸入 ssh -T git@github.com 進行測試,如果出現以下提示證明添加成功了。
4. Push & Pull
在提交代碼之前我們先要了解兩個命令,也是上次的文章沒有介紹的,因為這兩個命令需要跟遠程倉庫配合。
Push :直譯過來就是「推」的意思,什麼意思呢?如果你本地代碼有更新了,那麼就需要把本地代碼推到遠程倉庫,這樣本地倉庫跟遠程倉庫就可以保持同步了。
代碼示例: git push origin master
意思就是把本地代碼推到遠程 master 分支。
Pull:直譯過來就是「拉」的意思,如果別人提交代碼到遠程倉庫,這個時候你需要把遠程倉庫的最新代碼拉下來,然後保證兩端代碼的同步。
代碼示例: git pull origin master
意思就是把遠程最新的代碼更新到本地。一般我們在 push 之前都會先 pull ,這樣不容易衝突。
5. 提交代碼
添加 SSH key 成功之後,我們就有許可權向 GitHub 上我們自己的項目提交代碼了,而提交代碼有兩種方法:
Clone自己的項目
我們以我在 GitHub 上創建的 test 項目為例,執行如下命令:
git clone git@github.com:stormzhang/test.git
這樣就把 test 項目 clone 到了本地,你可以把 clone 命令理解為高級點的複製,這個時候該項目本身就已經是一個git 倉庫了,不需要執行 git init 進行初始化,而且甚至都已經關聯好了遠程倉庫,我們只需要在這個 test 目錄下任意修改或者添加文件,然後進行 commit ,之後就可以執行:
git push origin master
進行代碼提交,這種是最簡單方便的一種方式。
至於怎麼獲取項目的倉庫地址呢?如下圖:
關聯本地已有項目
如果我們本地已經有一個完整的 git 倉庫,並且已經進行了很多次 commit ,這個時候第一種方法就不適合了。
假設我們本地有個 test2 的項目,我們需要的是在 GitHub 上建一個 test 的項目,然後把本地 test2 上的所有代碼 commit 記錄提交到 GitHub 上的 test 項目。
第一步就是在 GitHub 上建一個 test 項目,這個想必大家都會了,就不用多講了。
第二步把本地 test2 項目與 GitHub 上的 test 項目進行關聯,切換到 test2 目錄,執行如下命令:
git remote add origin git@github.com:stormzhang/test.git
什麼意思呢?就是添加一個遠程倉庫,他的地址是 git@github.com:stormzhang/test.git ,而 origin 是給這個項目的遠程倉庫起的名字,是的,名字你可以隨便取,只不過大家公認的只有一個遠程倉庫時名字就是 origin ,為什麼要給遠程倉庫取名字?因為我們可能一個項目有多個遠程倉庫?比如 GitHub 一個,比如公司一個,這樣的話提交到不同的遠程倉庫就需要指定不同的倉庫名字了。
查看我們當前項目有哪些遠程倉庫可以執行如下命令:
git remote -v
接下來,我們本地的倉庫就可以向遠程倉庫進行代碼提交了:
git push origin master
就是默認向 GitHub 上的 test 目錄提交了代碼,而這個代碼是在 master 分支。當然你可以提交到指定的分支,這個之後的文章再詳細講解。
對了,友情提醒,在提交代碼之前先要設置下自己的用戶名與郵箱,這些信息會出現在所有的 commit 記錄里,執行以下代碼就可以設置:
git config —global user.name "stormzhang"
git config —global user.email "stormzhang.dev@gmail.com"
6. 總結
通過本文的介紹,終於大家可以成功的向 GitHub 提交代碼了,但是相信大家還有很多疑問,比如關於分支的理解與使用,比如 git 的其他一些有用的配置,比如怎麼向一些開源項目貢獻代碼,發起 Pull Request 等,之後的系列文章會逐一進行介紹,敬請期待。
PS:昨天的文章「如何在一群程序員中識別Android開發?」,是我寫這麼多文章以來第一次沒有一個反對意見的,回復全是清一色的「有理有據,深度好文」,還有表示「看了我的文章後特意去照了下鏡子,突然發現說的太他媽對了」,還有說「終於找到了為什麼一開始就選中 Android 的原因了」,我只能說,低調低調!
PS:以前你們生日的時候都在我文章底下評論求祝福,我給你們祝福過,號召點贊過,甚至還給有些人發過紅包,其實我想說,28年前的今天,一位偉大的程序員誕生了,因為天生長得帥,所以命中注定選擇了 Android 開發,今天終於輪到我生日了,還特意給你們準備了一篇乾貨,你們看著辦吧,讚賞、點擊廣告、轉發砸向我吧!
本文原創發佈於微信公眾號 AndroidDeveloper「googdev」,也許是最有人情味的技術公眾號,轉載請務必註明出處!
推薦閱讀:
※充話費送手機和買手機送話費有什麼本質的不同?
※關於miui植入廣告的問題,大家都是怎麼發現的?
※Jake Wharton 建議一個應用只使用一個 Activity
※自學編程這幾點非常重要