如要在 Android 應用程式中整合 Google 登入,請設定 Google 登入,並在應用程式的版面配置中新增按鈕,啟動登入流程。
事前準備
設定 Google API 控制台專案,並建立 Android Studio 專案。
設定 Google 登入和 GoogleSignInClient 物件
- 在登入活動的 - onCreate方法中設定 Google 登入,要求應用程式所需的使用者資料。舉例來說,如要設定 Google 登入要求使用者 ID 和基本個人資料資訊,請使用- DEFAULT_SIGN_IN參數建立- GoogleSignInOptions物件。如要一併要求使用者的電子郵件地址,請使用- requestEmail選項建立- GoogleSignInOptions物件。- // Configure sign-in to request the user's ID, email address, and basic // profile. ID and basic profile are included in DEFAULT_SIGN_IN. GoogleSignInOptions gso = new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_SIGN_IN) .requestEmail() .build(); - 如要要求其他範圍來存取 Google API,請使用 - requestScopes指定這些範圍。為提供最佳使用者體驗,登入時請只要求應用程式正常運作所需的最少範圍。只在需要時要求其他範圍,讓使用者在執行動作時看到同意畫面。請參閱「要求額外範圍」。
- 接著,在登入活動的 - onCreate方法中,使用您指定的選項建立- GoogleSignInClient物件。- // Build a GoogleSignInClient with the options specified by gso. mGoogleSignInClient = GoogleSignIn.getClient(this, gso); 
檢查現有的已登入使用者
在活動的 onStart 方法中,檢查使用者是否已透過 Google 登入應用程式。
// Check for existing Google Sign In account, if the user is already signed in // the GoogleSignInAccount will be non-null. GoogleSignInAccount account = GoogleSignIn.getLastSignedInAccount(this); updateUI(account);
如果 GoogleSignIn.getLastSignedInAccount 傳回 GoogleSignInAccount 物件 (而非 null),表示使用者已透過 Google 登入您的應用程式。視情況更新 UI,例如隱藏登入按鈕、啟動主要活動,或執行適合您應用程式的操作。
如果 GoogleSignIn.getLastSignedInAccount 傳回 null,表示使用者尚未透過 Google 登入您的應用程式。更新 UI,顯示 Google 登入按鈕。
在應用程式中新增 Google 登入按鈕
 在應用程式的版面配置中新增 在應用程式的版面配置中新增- SignInButton:- <com.google.android.gms.common.SignInButton android:id="@+id/sign_in_button" android:layout_width="wrap_content" android:layout_height="wrap_content" />
- 選用:如果您使用預設的登入按鈕圖片,而非提供自己的登入按鈕素材資源,可以使用 - setSize方法自訂按鈕大小。- // Set the dimensions of the sign-in button. SignInButton signInButton = findViewById(R.id.sign_in_button); signInButton.setSize(SignInButton.SIZE_STANDARD); 
- 在 Android 活動中 (例如 - onCreate方法中),註冊按鈕的- OnClickListener,使用者點按後即可登入:- findViewById(R.id.sign_in_button).setOnClickListener(this);
啟動登入流程
 在活動的 在活動的- onClick方法中,使用- getSignInIntent方法建立登入意圖,然後使用- startActivityForResult啟動意圖,藉此處理登入按鈕的輕觸事件。- @Override public void onClick(View v) { switch (v.getId()) { case R.id.sign_in_button: signIn(); break; // ... } }- private void signIn() { Intent signInIntent = mGoogleSignInClient.getSignInIntent(); startActivityForResult(signInIntent, RC_SIGN_IN); }- 啟動意圖後,系統會提示使用者選取要登入的 Google 帳戶。如果您要求取得 - profile、- email和- openid以外的資源,系統也會提示使用者授予這些資源的存取權。
- 使用者登入後,您可以在活動的 - onActivityResult方法中取得使用者的- GoogleSignInAccount物件。- @Override public void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); // Result returned from launching the Intent from GoogleSignInClient.getSignInIntent(...); if (requestCode == RC_SIGN_IN) { // The Task returned from this call is always completed, no need to attach // a listener. Task<GoogleSignInAccount> task = GoogleSignIn.getSignedInAccountFromIntent(data); handleSignInResult(task); } } - GoogleSignInAccount物件包含登入使用者的相關資訊,例如使用者名稱。- private void handleSignInResult(Task<GoogleSignInAccount> completedTask) { try { GoogleSignInAccount account = completedTask.getResult(ApiException.class); // Signed in successfully, show authenticated UI. updateUI(account); } catch (ApiException e) { // The ApiException status code indicates the detailed failure reason. // Please refer to the GoogleSignInStatusCodes class reference for more information. Log.w(TAG, "signInResult:failed code=" + e.getStatusCode()); updateUI(null); } } - 您也可以使用 - getEmail取得使用者的電子郵件地址、使用- getId取得使用者的 Google ID (供用戶端使用),以及使用- getIdToken取得使用者的 ID 權杖。如要將目前登入的使用者傳送至後端伺服器,請將 ID 權杖傳送至後端伺服器,並在伺服器上驗證權杖。
