天天看點

使用賬号密碼來操作github? NO!簡介背景介紹建立令牌使用令牌緩存令牌使用GCM總結

簡介

最近在更新github檔案的時候,突然說不讓更新了,讓我很是困惑,原因是在2021年8月13号之後,github已經不讓直接使用賬号名密碼來登入了,必須使用personal access token。今天給大家講解一下怎麼對這個token進行緩存。

背景介紹

github為了安全性考慮,在2020年7月就準備對所有需要使用身份認證的git指令切換成基于令牌的身份驗證。并且從2021年8月13日開始,在 GitHub.com上對Git操作進行身份驗證時将不再接受帳戶密碼。

這個改動隻對使用使用者名密碼進行github互動的使用者受影響。如果你使用的是SSH,或者之前就使用的是令牌,或者使用的是GitHub Desktop,那麼不會有任何影響。

github做出這個決定主要是對于安全的考慮,明文的密碼很容易被洩露,如果換成有時限的token,即使洩露了影響也會非常有限。

并且可以為同一個github賬号根據不同的使用途徑,生成不同的token,并且随時都可以控制token的有效狀态和不同token代表的權限。最大限度的保證賬号的安全性。

生成的token可随時撤銷,并且令牌的随機性更高,不容易被暴力破解。

建立令牌

令牌,英文名叫做token,個人通路令牌英文簡寫為PAT。它是一種使用密碼對 GitHub 進行身份驗證的替代方法。

你可以将token看做是密碼,不過這個token具有權限和有效時間的限制。同時為了安全起見,GitHub 會自動删除一年内未使用的個人通路令牌。 為了保證令牌的安全性,我們強烈建議為個人通路令牌添加過期時間。

要使用令牌首先需要建立令牌。怎麼建立令牌呢?

首先登入github.com,在我的賬号下方,選擇settings:

然後在左側邊欄中,點選開發人員設定:

然後選擇左邊的個人通路令牌:

點選生成令牌按鈕,就可以生成令牌了。

在建立過程中,我們需要輸入和選擇一些資料:

比如我們需要給這個token起個名字,用來區分不同的使用場景,還要選擇一個過期時間,為了安全起見,這個過期時間不要太長。

最後,就是token對應的權限了,如果你隻是對repository進行操作,選擇repo即可。

這樣一個令牌就建立好了。

注意,建立好的令牌需要及時儲存,因為後續也不能再從網頁上檢視該令牌的内容。令牌的儲存需要和密碼的儲存一樣注意安全。

使用令牌

上面我們提到了,令牌就相當于密碼,比如我們在拷貝一個需要密碼的repository使用輸入你的使用者名和token就可以正常操作了。

$ git clone https://github.com/username/repo.git
Username: your_username
Password: your_token      

但是如果每次都需要輸入密碼就太麻煩了。下面講解一下怎麼在git中緩存令牌。事實上令牌跟密碼是等價的,在git中緩存密碼的方式同樣适用于緩存令牌。

緩存令牌

通過設定credential.helper的緩存方式,可以對密碼進行緩存。

通常來說有兩種方式,一種是cache,一種是store。

cache是将密碼放在記憶體中一段時間,密碼不會存放在磁盤中,過一段時間會自動從記憶體中清除。

通過使用下面的指令,可以開啟cache:

git config --global credential.helper cache      

對于store來說,它接收一個檔案的路徑,用來存儲密碼檔案。預設存放的路徑是~/.git-credentials,可以通過指定–file來修改:

git config --global credential.helper 'store --file /data/git/.git-credentials'      

如果你使用的mac系統,mac提供了一個osxkeychain的東西,可以将密碼存儲到你的系統使用者的鑰匙串中。這種方式更加優雅,首先密碼是加密儲存的,另外其管理起來也非常友善,還有可視化的界面。

當然你也可以從指令行将github的存儲密碼進行删除:

$ git credential-osxkeychain erase
host=github.com
protocol=https
> [Press Return]      

如果你在windows機子上,那麼可以安裝一個叫做““Git Credential Manager for Windows”的工具,它是一個和osxkeychain類似的東西。

使用GCM

上面介紹的存儲方法都已經過時了,現在github推薦使用Git Credential Manager Core (GCM Core) 來對你的用戶端憑證進行管理。

通過使用GCM Core,根本不需要建立和儲存PAT,全部都有GCM Core來代表你進行管理。

怎麼安裝GCM呢?下面是在mac上安裝的過程:

首先安裝git:

brew install git      

然後安裝GCM Core:

$ brew tap microsoft/git
$ brew install --cask git-credential-manager-core      

在下次你clone需要使用身份驗證的HTTPS URL時,Git将會提示你使用浏覽器視窗登入,通過授權OAuth應用程式,實作GCM Core對憑證的管理功能。

成功通過身份驗證後,你的憑據将存儲在macOS鑰匙串中,并且每次克隆HTTPS URL時都會使用鑰匙串中的憑證。 Git不會要求你再次在指令行中鍵入憑據,除非你更改憑據。

GCM Core同樣可以在windows和linux環境下使用。

總結

通過生成新的token,并更換現有的緩存密碼,最終我的github又可以重新送出了,贊!

本文已收錄于 http://www.flydean.com/05-git-personal-access-token/

最通俗的解讀,最深刻的幹貨,最簡潔的教程,衆多你不知道的小技巧等你來發現!

歡迎關注我的公衆号:「程式那些事」,懂技術,更懂你!

繼續閱讀