Google Services Gradle 外掛程式

引言

在 Android 應用程式中啟用 Google API 或 Firebase 服務時,可能需要將 google-services 外掛程式新增至 build.gradle 檔案:

dependencies {
    classpath 'com.google.gms:google-services:4.4.1'
    // ...
}

google-services 外掛程式有兩個主要函式:

  1. 處理 google-services.json 檔案並產生可用於應用程式程式碼的 Android 資源。詳情請參閱新增 JSON 檔案
  2. 針對已啟用的服務,新增基本程式庫所需的依附元件。這個步驟需要您在 app/build.gradle 檔案中套用 Google Services Gradle 外掛程式,如下所示:
    apply plugin: 'com.google.gms.google-services'

    您可以執行 ./gradlew :app:dependencies 來查看這個步驟的結果。

新增 JSON 檔案

google-services.json 檔案通常位於 app/ 目錄 (Android Studio 應用程式模組的根目錄中)。自 2.2.0 版起,外掛程式可支援建構類型和變種版本專用的 JSON 檔案。以下所有目錄結構都有效:

// dogfood and release are build types.
app/
    google-services.json
    src/dogfood/google-services.json
    src/release/google-services.json
    ...

注意:您可以在發布目錄中提供 google-services.json 檔案,這樣就能為正式版 APK 維護獨立的 Firebase 專案。

變種版本在使用中,這些較複雜的目錄結構也會有效。

// free and paid are product flavors.
app/
    google-services.json
    src/dogfood/paid/google-services.json
    src/release/free/google-services.json
    ...

處理 JSON 檔案

google-services.json 檔案的基本結構如下:

{
  "project_info": {...},
  "client": [...],
}

project_info 物件包含專案的一般資訊,而 client 陣列的每個成員則都包含已加進專案的用戶端 (Android 應用程式) 相關資訊。

處理 Android 應用程式的 JSON 檔案時,外掛程式只會根據下列邏輯,使用與套件名稱 (針對目前建構類型) 相符的 client 物件:

  • 針對 client 陣列的每一個成員:
    • 查看 client_info/android_client_info/package_name 的值
    • 如果套件名稱與這個值相符,就會傳回成員物件。
  • 如果 client 的成員都與套件名稱不符,便會擲回例外狀況。

在本文件的其餘部分中,我們會使用 {YOUR_CLIENT} 來參照上述程序所確定的 client 陣列成員。

JSON 處理的主要結果是產生兩個 XML 檔案,您可以在 Java 程式碼中以 Android 資源的形式參照這些檔案。以下是每個檔案的範例:

app/build/generated/res/google-services/{build_type}/values/values.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>

    <! -- Present in all applications -->
    <string name="google_app_id" translatable="false">1:1035469437089:android:73a4fb8297b2cd4f</string>

    <! -- Present in applications with the appropriate services configured -->
    <string name="gcm_defaultSenderId" translatable="false">1035469437089</string>
    <string name="default_web_client_id" translatable="false">337894902146-e4uksm38sne0bqrj6uvkbo4oiu4hvigl.apps.googleusercontent.com</string>
    <string name="ga_trackingId" translatable="false">UA-65557217-3</string>
    <string name="firebase_database_url" translatable="false">https://example-url.firebaseio.com</string>
    <string name="google_api_key" translatable="false">AIzbSyCILMsOuUKwN3qhtxrPq7FFemDJUAXTyZ8</string>
    <string name="google_crash_reporting_api_key" translatable="false">AIzbSyCILMsOuUKwN3qhtxrPq7FFemDJUAXTyZ8</string>
    <string name="project_id" translatable="false">mydemoapp</string>

</resources>

app/build/generated/res/google-services/{flavor}/{build_type}/xml/global_tracker.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <string name="ga_trackingId" translatable="false">UA-65557218-3</string>
</resources>

XML 檔案中的每個值都位於以下位置的 google-services.json 檔案中。如果 Android 專案的某些設定會導致您無法使用 google-services 外掛程式,您可以使用這些值安全地手動重建 XML 檔案:

google_app_id:

{YOUR_CLIENT}/client_info/mobilesdk_app_id

gcm_defaultSenderId

project_info/project_number

default_web_client_id:

{YOUR_CLIENT}/oauth_client/client_id (client_type == 3)

ga_trackingId:

{YOUR_CLIENT}/services/analytics-service/analytics_property/tracking_id

firebase_database_url:

project_info/firebase_url

google_api_key:

{YOUR_CLIENT}/api_key/current_key

google_crash_reporting_api_key:

{YOUR_CLIENT}/api_key/current_key

project_id

project_info/project_id

疑難排解

問:建構時會收到以下錯誤訊息:「Module google-services.json 缺少來自模組根資料夾。沒有 Google 服務外掛程式就無法運作。」

答:Firebase 控制台可協助您下載 google-services.json。此外,大多數 API 的快速入門導覽課程指南都有產生此檔案的操作說明。下載 google-services.json 檔案後,請將其複製到 Android Studio 專案的 app/ 資料夾;如果您使用多種建構類型,則複製到 app/src/{build_type} 資料夾。

問:我找不到「R.string.gcm_defaultSenderId」、「R.xml.global_tracker」等符號

答:確認 build.gradle 檔案中的套件名稱與建立 google-services.json 檔案時輸入的套件名稱相符。如果不確定,請再次執行該流程,並取得新的 JSON 檔案。