アプリにGoogleSignInオプションを提供しました。
これが私のコードです:
public class SignupActivity extends AppCompatActivity {
private static final int RC_SIGN_IN = 1;
GoogleApiClient mGoogleApiClient;
FirebaseAuth mAuth;
TextView appName;
ProgressDialog signinProgressDialog;
CoordinatorLayout coordinatorLayout;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_signup);
// Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
// setSupportActionBar(toolbar);
signinProgressDialog = new ProgressDialog(SignupActivity.this);
coordinatorLayout = (CoordinatorLayout) findViewById(R.id.signupCoordinatorLayout);
// Configure Google Sign In
GoogleSignInOptions gso = new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_SIGN_IN)
.requestIdToken(getString(R.string.o_auth_client_id))
.requestEmail()
.requestProfile()
.requestId()
.build();
// Build a GoogleApiClient with access to the Google Sign-In API and the
// options specified by gso.
mGoogleApiClient = new GoogleApiClient.Builder(this)
.enableAutoManage(this /* FragmentActivity */, new GoogleApiClient.OnConnectionFailedListener() {
@Override
public void onConnectionFailed(@NonNull ConnectionResult connectionResult) {
}
} /* OnConnectionFailedListener */)
.addApi(Auth.GOOGLE_SIGN_IN_API, gso)
.build();
mAuth = FirebaseAuth.getInstance();
findViewById(R.id.sign_in_button).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (isNetworkAvailable()) {
signinProgressDialog.setMessage("Signing in...");
signinProgressDialog.show();
signIn();
} else {
Snackbar snackbar = Snackbar
.make(coordinatorLayout, "No internet connection!", Snackbar.LENGTH_LONG);
snackbar.show();
signinProgressDialog.dismiss();
}
}
});
}
private void signIn() {
Intent signInIntent = Auth.GoogleSignInApi.getSignInIntent(mGoogleApiClient);
startActivityForResult(signInIntent, RC_SIGN_IN);
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
// Result returned from launching the Intent from GoogleSignInApi.getSignInIntent(...);
if (requestCode == RC_SIGN_IN) {
GoogleSignInResult result = Auth.GoogleSignInApi.getSignInResultFromIntent(data);
if (result.isSuccess()) {
// Google Sign In was successful, authenticate with Firebase
GoogleSignInAccount account = result.getSignInAccount();
firebaseAuthWithGoogle(account);
} else {
// Google Sign In failed, update UI appropriately
// ...
Snackbar snackbar = Snackbar
.make(coordinatorLayout, "Error signing in!", Snackbar.LENGTH_LONG);
snackbar.show();
signinProgressDialog.dismiss();
}
}
}
private void firebaseAuthWithGoogle(GoogleSignInAccount acct) {
Log.d("firebaseAuthWithGoogle", "firebaseAuthWithGoogle:" + acct.getId());
AuthCredential credential = GoogleAuthProvider.getCredential(acct.getIdToken(), null);
mAuth.signInWithCredential(credential)
.addOnCompleteListener(this, new OnCompleteListener<AuthResult>() {
@Override
public void onComplete(@NonNull Task<AuthResult> task) {
Log.d("signin_successful", "signInWithCredential:onComplete:" + task.isSuccessful());
Intent mainActivityIntent = new Intent(SignupActivity.this, MainActivity.class);
mainActivityIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
mainActivityIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK);
startActivity(mainActivityIntent);
signinProgressDialog.dismiss();
// If sign in fails, display a message to the user. If sign in succeeds
// the auth state listener will be notified and logic to handle the
// signed in user can be handled in the listener.
if (!task.isSuccessful()) {
Log.w("signin_unsuccessful", "signInWithCredential", task.getException());
Toast.makeText(SignupActivity.this, "Authentication failed.",
Toast.LENGTH_SHORT).show();
signinProgressDialog.dismiss();
}
// ...
}
});
}
@Override
public void onBackPressed() {
finish();
super.onBackPressed();
}
private boolean isNetworkAvailable() {
ConnectivityManager connectivityManager
= (ConnectivityManager) SignupActivity.this.getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo activeNetworkInfo = connectivityManager.getActiveNetworkInfo();
return activeNetworkInfo != null && activeNetworkInfo.isConnected();
}
}
私は2つのクライアントIDを持っています。1つはWebクライアントで、もう1つはAndroidクライアントです。
google-services.json
ファイルとconsole.developers.google.comのプロジェクトでクライアントIDを確認しました。これらはすべて一致しています。
しかし、まだこのエラーが発生しています:E/TokenRequestor: You have wrong OAuth2 related configurations, please check. Detailed error: INVALID_AUDIENCE 06-27 12:40:14.651 4443-4484/? D/AuthAccountOperation: id token request failed.
このエラーの原因は何でしょうか?
それは私のアプリが私のコンソール上の私のアプリに接続されなくなったためですか、それとも何か他のものですか?
私にお知らせください。
プロジェクト設定でSHAアプリごとにAndroidアプリを追加する必要があります。Firebaseを使用している場合は、プロジェクト名を使用して以下のリンクを編集してから、アプリのフィンガープリント。
https://console.firebase.google.com/project/{YOUR_PROJECT_NAME}/settings/general/
私はこの質問にかなり遅れていると思います。ただし、Google-service.jsonファイルの同期をfirebaseと更新することで、この問題を解決できます。
ツール-> Firebase->アナリティクス-> Firebaseに接続
アプリを作成するか、すでに存在する場合は同期します。
よろしく
Googleアカウントでログインに成功したい場合は、次のようにする必要があります。1。apk(たとえば、packageNameは 'com.example.xxx'、キーストアのSHA1は 'qwertyuiop ....')をGoogle DeveloperConsoleにアップロードしてからClientIDを取得します。 2.取得した正しいClientIDを使用し、SHA1が「qwertyuiop ...」である正しいキーストアファイルを使用してapkに署名します。通常は作成できます。
それでもログインに成功しません。上記の手順のいずれかが間違っている必要があります。手順を追って確認してください。私の推測では、キーストアファイルがdebugModeに対して間違っている可能性があります。