要透過 Google Cloud Platform (GCP) 的 OAuth 2.0 Client IDs 存取任何 Google 雲端服務,除了要走過 OAuth 2.0 的授權流程外,每個服務都需要事先啟用才能使用。除此之外,你還需要設定 CONSENT SCREEN 才行,這篇文章我打算來解說第一次設定 Google 服務與 OAuth 2.0 Client IDs 的注意事項。
整體設定步驟
基本上第一次使用 Google 服務的人,都要走過以下步驟:
-
進入 Google Cloud Console 建立第一個專案 (Project)
data:image/s3,"s3://crabby-images/d4242/d42423d2be24e052537b80ed3e74cd8d1af25487" alt="Google Cloud Console"
-
設定 OAuth consent screen 資訊
data:image/s3,"s3://crabby-images/14fc2/14fc2774db88d05c997399c356638a4d4fef5a9a" alt="OAuth consent screen"
-
建立 Credentials > OAuth 2.0 Client ID
data:image/s3,"s3://crabby-images/d9f76/d9f76796c732e4d85c310a0ee06215ba33904f2e" alt="Credentials > OAuth 2.0 Client ID"
-
啟用 API 服務
data:image/s3,"s3://crabby-images/eacbf/eacbf3f6cafcfd4480231391529af4b6e660154f" alt="啟用 API 服務"
設定 OAuth consent screen 資訊
在 GCP 每個 Project 只能設定一組 OAuth consent screen 資訊,也只需要設定一次,且一定要先設定才能使用 OAuth 授權流程,以下是設定步驟:
-
選擇 External
類型
data:image/s3,"s3://crabby-images/b312b/b312bd04d96f7dbe42d1116ca87e5ba938ece8de" alt="image"
-
OAuth consent screen: 設定 App Name
與其他必填設定
data:image/s3,"s3://crabby-images/06700/06700c6f2b8da05b34db2f2885de43f47a3d0241" alt="image"
-
Scopes: 這裡可以不用設定,直接按下 SAVE AND CONTINUE
繼續
-
Test Users: 此步驟十分重要,你要將你的 Google 帳號加入到測試使用者清單中,之後才能進行 OAuth 測試!
data:image/s3,"s3://crabby-images/0ead0/0ead067f634aafcc129341e8504c1b2914064106" alt="image"
如果沒有正確加入測試使用者清單的話,使用 OAuth 2.0 授權時就會出現以下錯誤:
data:image/s3,"s3://crabby-images/34ace/34acefd0c0aac04d4817c70058c7887a68b9f0e9" alt="image"
初始設定完成!
啟用 API 服務
每一個要透過 OAuth 2.0 Client IDs 存取的服務,都需要事先啟用 API 才能跟 OAuth 進行整合,以下是啟用服務的步驟:
-
先進入 Google Cloud Console 頁面
-
我以 Google Drive API 為例,請在最上方輸入 Google Drive
關鍵字搜尋
data:image/s3,"s3://crabby-images/5eb6b/5eb6b5f7e9b17c1190fe8f057c996854f6170ad6" alt="image"
-
點擊 ENABLE
即可啟用 API 服務
data:image/s3,"s3://crabby-images/eacbf/eacbf3f6cafcfd4480231391529af4b6e660154f" alt="image"
如果要停用服務,可以參考以下步驟:
-
先進入 Google Cloud Console 頁面
-
我以 Google Drive API 為例,請在最上方輸入 Google Drive
關鍵字搜尋
-
點擊 MANAGE
進入管理頁面
data:image/s3,"s3://crabby-images/d3bc6/d3bc6176f4535cf03fbbe2451390487fbb9f37d4" alt="image"
-
點擊 DISABLE API
即可停用 API 服務
data:image/s3,"s3://crabby-images/4718d/4718da30d4806feda8d67ba21f5dd82545fb8416" alt="image"
如果有任何資源是透過 Google Drive API 建立的,在 Google Drive API 被停用後可能會很快被刪除。
所有使用此專案的 Credentials (憑證) 呼叫 Google Drive API 的程式碼都將失效!
data:image/s3,"s3://crabby-images/590a6/590a6031c36ac9a4477fe91e4b9d058d55636dab" alt="image"
相關連結