Android Google+ Login funktioniert nicht - statusCode = SIGN_IN_REQUIRED
Ich versuche, den Benutzer mit Google+ anmelden zu lassen. Ich habe das Projekt in der Google-Entwicklerkonsole erstellt, die Client-ID erhalten und die Google Play-Dienste in Android Studio installiert. (Mein laufendes Gerät hat Android 4.4.2.) Wenn die App ausgeführt wird und ich die Anmeldetaste drücke, wird eine Toastmeldung angezeigt: "Interner Fehler"
Der Fehler im Logcat ist der folgende:
error ConnectionResult{statusCode=SIGN_IN_REQUIRED, resolution=PendingIntent{429ffe38: android.os.BinderProxy@429ffdd8}}
Bitte beachten Sie, dass dieser Fehler auftritt, bevor der Benutzer die Taste gedrückt hat. Durch das Debuggen habe ich herausgefunden, dass er von folgendem Zeilencode stammt:
Log.e(TAG, "error " + result.toString());
was ist in der Methode:
public void onConnectionFailed(ConnectionResult result) {
if (!mGoogleIntentInProgress) {
/* Store the ConnectionResult so that we can use it later when the user clicks on the Google+ login button */
mGoogleConnectionResult = result;
if (mGoogleLoginClicked) {
/* The user has already clicked login so we attempt to resolve all errors until the user is signed in,
* or they cancel. */
resolveSignInError();
} else {
Log.e(TAG, "error " + result.toString());
}
}
}
Hier die anderen wichtigen Methoden:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login);
SignInButton googleLoginButton = (SignInButton) findViewById(R.id.login_with_google);
googleLoginButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
mGoogleLoginClicked = true;
if (!mGoogleApiClient.isConnecting()) {
if (mGoogleConnectionResult != null) {
resolveSignInError();
} else if (mGoogleApiClient.isConnected()) {
getGoogleOAuthTokenAndLogin();
} else {
/* connect API now */
Log.d(TAG, "Trying to connect to Google API");
mGoogleApiClient.connect();
}
}
}
});
/* Setup the Google API object to allow Google+ logins */
mGoogleApiClient = new GoogleApiClient.Builder(this)
.addConnectionCallbacks(this)
.addOnConnectionFailedListener(this)
.addApi(Plus.API)
.addScope(Plus.SCOPE_PLUS_LOGIN)
.build();
}
private void resolveSignInError() {
if (mGoogleConnectionResult.hasResolution()) {
try {
mGoogleIntentInProgress = true;
mGoogleConnectionResult.startResolutionForResult(this, RC_GOOGLE_LOGIN);
} catch (IntentSender.SendIntentException e) {
// The intent was canceled before it was sent. Return to the default
// state and attempt to connect to get an updated ConnectionResult.
mGoogleIntentInProgress = false;
mGoogleApiClient.connect();
}
}
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == RC_GOOGLE_LOGIN) {
/* This was a request by the Google API */
if (resultCode != RESULT_OK) {
mGoogleLoginClicked = false;
}
mGoogleIntentInProgress = false;
if (!mGoogleApiClient.isConnecting()) {
mGoogleApiClient.connect();
}
}
}
Hier der Code in der AndroidManifest.xml
<uses-permission android:name="android.permission.USE_CREDENTIALS" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.INTERNET" />
Und die Metadaten
<meta-data
android:name="com.google.android.gms.version"
android:value="@integer/google_play_services_version" />
Hoffentlich können Sie mir helfen, vielen Dank!