從0開始學習 GitHub 系列之「04.向GitHub 提交代碼」
之前的這篇文章「從0開始學習 GitHub 系列之「Git速成」」相信大家都已經(jīng)對 Git 的基本操作熟悉了,但是這篇文章只介紹了對本地 Git 倉庫的基本操作,今天我就來介紹下如何跟遠程倉庫一起協(xié)作,教你們向 GitHub 上提交你們的第一行代碼!
本文引用地址:http://www.ex-cimer.com/article/201704/358581.htm1. SSH
你擁有了一個 GitHub 賬號之后,就可以自由的 clone 或者下載其他項目,也可以創(chuàng)建自己的項目,但是你沒法提交代碼。仔細想想也知道,肯定不可能隨意就能提交代碼的,如果隨意可以提交代碼,那么 GitHub 上的項目豈不亂了套了,所以提交代碼之前一定是需要某種授權的,而 GitHub 上一般都是基于 SSH 授權的。
那么什么是 SSH 呢?
簡單點說,SSH是一種網(wǎng)絡協(xié)議,用于計算機之間的加密登錄。目前是每一臺 Linux 電腦的標準配置。而大多數(shù) Git 服務器都會選擇使用 SSH 公鑰來進行授權,所以想要在 GitHub 提交代碼的第一步就是要先添加 SSH key 配置。
2. 生成SSH key
Linux 與 Mac 都是默認安裝了 SSH ,而 Windows 系統(tǒng)安裝了 Git Bash 應該也是帶了 SSH 的。大家可以在終端(win下在 Git Bash 里)輸入 ssh 如果出現(xiàn)以下提示證明你本機已經(jīng)安裝 SSH, 否則請搜索自行安裝下。
緊接著輸入 ssh-keygen -t rsa ,什么意思呢?就是指定 rsa 算法生成密鑰,接著連續(xù)三個回車鍵(不需要輸入密碼),然后就會生成兩個文件 id_rsa 和 id_rsa.pub ,而 id_rsa 是密鑰,id_rsa.pub 就是公鑰。這兩文件默認分別在如下目錄里生成:
Linux/Mac 系統(tǒng) 在 ~/.ssh 下,win系統(tǒng)在 /c/Documents and Settings/username/.ssh 下,都是隱藏文件,相信你們有辦法查看的。
接下來要做的是把 id_rsa.pub 的內(nèi)容添加到 GitHub 上,這樣你本地的 id_rsa 密鑰跟 GitHub 上的 id_rsa.pub 公鑰進行配對,授權成功才可以提交代碼。
3. GitHub 上添加 SSH key
第一步先在 GitHub 上的設置頁面,點擊最左側 SSH and GPG keys :
然后點擊右上角的 New SSH key 按鈕:
需要做的只是在 Key 那欄把 id_rsa.pub 公鑰文件里的內(nèi)容復制粘貼進去就可以了(上述示例為了安全粘貼的公鑰是無效的),Title 那欄不需要填寫,點擊 Add SSH key 按鈕就ok了。
這里提醒下,怎么查看 id_rsa.pub 文件的內(nèi)容?
Linux/Mac 用戶執(zhí)行以下命令:
cd ~/.ssh
cat id_rsa.pub
Windows用戶,設置顯示隱藏文件,可以使用 EditPlus 或者 Sublime 打開復制就行了。
SSH key 添加成功之后,輸入 ssh -T git@github.com 進行測試,如果出現(xiàn)以下提示證明添加成功了。
4. Push & Pull
在提交代碼之前我們先要了解兩個命令,也是上次的文章沒有介紹的,因為這兩個命令需要跟遠程倉庫配合。
Push :直譯過來就是「推」的意思,什么意思呢?如果你本地代碼有更新了,那么就需要把本地代碼推到遠程倉庫,這樣本地倉庫跟遠程倉庫就可以保持同步了。
代碼示例: git push origin master
意思就是把本地代碼推到遠程 master 分支。
Pull:直譯過來就是「拉」的意思,如果別人提交代碼到遠程倉庫,這個時候你需要把遠程倉庫的最新代碼拉下來,然后保證兩端代碼的同步。
代碼示例: git pull origin master
意思就是把遠程最新的代碼更新到本地。一般我們在 push 之前都會先 pull ,這樣不容易沖突。
5. 提交代碼
添加 SSH key 成功之后,我們就有權限向 GitHub 上我們自己的項目提交代碼了,而提交代碼有兩種方法:
Clone自己的項目
我們以我在 GitHub 上創(chuàng)建的 test 項目為例,執(zhí)行如下命令:
git clone git@github.com:stormzhang/test.git
這樣就把 test 項目 clone 到了本地,你可以把 clone 命令理解為高級點的復制,這個時候該項目本身就已經(jīng)是一個git 倉庫了,不需要執(zhí)行 git init 進行初始化,而且甚至都已經(jīng)關聯(lián)好了遠程倉庫,我們只需要在這個 test 目錄下任意修改或者添加文件,然后進行 commit ,之后就可以執(zhí)行:
git push origin master
進行代碼提交,這種是最簡單方便的一種方式。
至于怎么獲取項目的倉庫地址呢?如下圖:
關聯(lián)本地已有項目
如果我們本地已經(jīng)有一個完整的 git 倉庫,并且已經(jīng)進行了很多次 commit ,這個時候第一種方法就不適合了。
假設我們本地有個 test2 的項目,我們需要的是在 GitHub 上建一個 test 的項目,然后把本地 test2 上的所有代碼 commit 記錄提交到 GitHub 上的 test 項目。
第一步就是在 GitHub 上建一個 test 項目,這個想必大家都會了,就不用多講了。
第二步把本地 test2 項目與 GitHub 上的 test 項目進行關聯(lián),切換到 test2 目錄,執(zhí)行如下命令:
git remote add origin git@github.com:stormzhang/test.git
什么意思呢?就是添加一個遠程倉庫,他的地址是 git@github.com:stormzhang/test.git ,而 origin 是給這個項目的遠程倉庫起的名字,是的,名字你可以隨便取,只不過大家公認的只有一個遠程倉庫時名字就是 origin ,為什么要給遠程倉庫取名字?因為我們可能一個項目有多個遠程倉庫?比如 GitHub 一個,比如公司一個,這樣的話提交到不同的遠程倉庫就需要指定不同的倉庫名字了。
查看我們當前項目有哪些遠程倉庫可以執(zhí)行如下命令:
git remote -v
接下來,我們本地的倉庫就可以向遠程倉庫進行代碼提交了:
git push origin master
就是默認向 GitHub 上的 test 目錄提交了代碼,而這個代碼是在 master 分支。當然你可以提交到指定的分支,這個之后的文章再詳細講解。
對了,友情提醒,在提交代碼之前先要設置下自己的用戶名與郵箱,這些信息會出現(xiàn)在所有的 commit 記錄里,執(zhí)行以下代碼就可以設置:
git config —global user.name "stormzhang"
git config —global user.email "stormzhang.dev@gmail.com"
6. 總結
通過本文的介紹,終于大家可以成功的向 GitHub 提交代碼了,但是相信大家還有很多疑問,比如關于分支的理解與使用,比如 git 的其他一些有用的配置,比如怎么向一些開源項目貢獻代碼,發(fā)起 Pull Request 等,之后的系列文章會逐一進行介紹,敬請期待。
評論