Я пытаюсь войти в систему Google для работы с моим приложением. Пока думаю, что все сделал правильно. Я следил за документацией Google по настройке googlesigninclient и могу заставить приложение добраться до кнопки входа, но когда кто-то пытается войти в систему, он возвращает ошибку 12500 (SIGN_IN_FAILED). У меня правильно настроены учетные данные google api, и они правильно настроены в моем debug.keystore, и у меня есть загруженный файл credentials.json и в папке моего приложения. Я отправлю свой код, кто-нибудь знает, почему он не работает?
Спасибо!
P.S. Просто чтобы отвлечь людей от прохода, я тестировал его на своем телефоне, на котором определенно установлена последняя версия сервисов Google Play, поэтому я не думаю, что это проблема.
import android.content.Intent;
import android.support.v4.app.FragmentManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.TextView;
import com.google.android.gms.auth.api.Auth;
import com.google.android.gms.auth.api.signin.GoogleSignIn;
import com.google.android.gms.auth.api.signin.GoogleSignInAccount;
import com.google.android.gms.auth.api.signin.GoogleSignInClient;
import com.google.android.gms.auth.api.signin.GoogleSignInOptions;
import com.google.android.gms.auth.api.signin.GoogleSignInResult;
import com.google.android.gms.common.SignInButton;
import com.google.android.gms.common.api.ApiException;
import com.google.android.gms.common.api.Scope;
import com.google.android.gms.tasks.Task;
public class MainActivity extends AppCompatActivity {
GoogleSignInClient mGoogleSignInClient;
private static int RC_SIGN_IN = 100;
private static final String TAG = "MainActivity";
private SignInButton signInButton = null;
private LinearLayout calendarLayout;
private TextView email;
private TextView name;
private TextView getId;
private TextView scopes;
//private Scope scope = new Scope("https://www.googleapis.com/auth/calendar.events.readonly");
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
GoogleSignInOptions gso = new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_SIGN_IN)
.requestEmail()
.build();
mGoogleSignInClient = GoogleSignIn.getClient(this, gso);
signInButton = findViewById(R.id.sign_in_button);
signInButton.setSize(SignInButton.SIZE_STANDARD);
signInButton.setColorScheme(SignInButton.COLOR_LIGHT);
}
@Override
public void onStart() {
super.onStart();
// [START on_start_sign_in]
// 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);
// [END on_start_sign_in]
}
@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);
}
}
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);
}
}
public void updateUI(GoogleSignInAccount account) {
if (account == null) {
loadLogin();
} else {
loadCalendar(account);
}
}
public void loadCalendar(GoogleSignInAccount account) {
if (signInButton != null) {
signInButton.setVisibility(View.INVISIBLE);
}
calendarLayout = findViewById(R.id.calendarLinearLayout);
calendarLayout.setVisibility(View.VISIBLE);
name = findViewById(R.id.name);
name.setText(account.getDisplayName());
email = findViewById(R.id.email);
email.setText(account.getEmail());
getId = findViewById(R.id.getId);
getId.setText(account.getId());
scopes = findViewById(R.id.scopes);
scopes.setText(account.getRequestedScopes().toString());
}
private void loadLogin() {
signInButton.setVisibility(View.VISIBLE);
signInButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
onSignInClicked();
}
});
}
private void onSignInClicked() {
Intent signInIntent = mGoogleSignInClient.getSignInIntent();
startActivityForResult(signInIntent, RC_SIGN_IN);
}
}
Вот некоторые журналы, которые он поместил в logcat:
10-30 07:19:09.987 1832-1832/com.example.aydus.cs356app D/dalvikvm: GC_FOR_ALLOC freed 275K, 11% free 3222K/3584K, paused 2ms, total 2ms
10-30 07:22:50.604 1832-1838/com.example.aydus.cs356app E/jdwp: REQ: UNSUPPORTED (cmd=6/3 dataLen=12 id=0x005baf)
10-30 07:22:57.934 1832-1832/com.example.aydus.cs356app W/EGL_emulation: eglSurfaceAttrib not implemented 3093 12436
10-30 07:26:50.601 1832-1832/com.example.aydus.cs356app W/MainActivity: signInResult:failed code=12500
@SachinKasaraddi обновлен
Ничего не найдено в журнале, связанном с SIGN_IN_FAILED
@SachinKasaraddi правда. Я удалил те. Вот пример из вкладки запуска в Android Studio W / MainActivity: signInResult: failed code = 10
@SachinKasaraddi На самом деле обновление, когда оно выдало код ошибки = 10, который был на эмуляторе на моем компьютере, но когда я пытаюсь запустить его, o W / MainActivity: signInResult: failed code = 12500
Попробуйте войти с другой учетной записью Google developers.google.com/android/reference/com/google/android/g ms /…
Я просто попробовал и получил тот же результат
Просто обновите свои сервисы Google Play до последней версии (или 11720000 в данном случае). Если вы используете AVD, образы Nexus 5 и 5X поддерживают Google Play. Как только эмулятор будет запущен, перейдите в меню расширенных элементов управления> Google Play, затем обновите
@SachinKasaraddi Я тоже попробовал на своем телефоне и получил тот же код ошибки. и мой телефон определенно обновлен до последней версии, поэтому я не думаю, что проблема в версии сервисов Google Play
@SachinKasaraddi Я уже сказал, что проблема не в версии Google Play
Просто обновите свои сервисы Google Play до последней версии. Если вы используете AVD, образы Nexus 5 и 5X поддерживают Google Play. После того, как эмулятор будет запущен, перейдите в меню расширенных элементов управления> Google Play, затем обновите.
Я тестировал его на своем телефоне с последней версией сервисов Google Play, и он все равно дал мне эту ошибку
Я также тестировал этот ответ, но ошибка 12500 все еще появляется
Удачи, найдем любое решение> @ Huy-Logarit
Код ошибки 10: DEVELOPER_ERROR: https://developers.google.com/android/reference/com/google/android/gms/common/api/CommonStatusCodes.html#DEVELOPER_ERROR
Это почти наверняка означает, что вы неправильно зарегистрировали свой SHA1 и имя пакета в консоли Google API: https://developers.google.com/identity/sign-in/android/start
Если вы на 100% уверены, что сделали это правильно, убедитесь, что ваши параметры GoogleSignInOptions верны. В частности, убедитесь, что идентификатор веб-клиента (если вы его используете) принадлежит тому же проекту, в котором вы зарегистрировали имя своего пакета и SHA1.
Для меня это было потому, что я включил подписку в Google Play, поэтому вам нужно получить SHA1 из раздела Управление релизами -> Подпись приложения -> «Сертификат подписи приложения»
Когда ваше приложение появится в магазине Google Play, вам необходимо использовать SHA1 с помощью предоставленного метода. Благодарю. работал.
Это может быть запоздалый ответ, но кому-то он поможет. Включите Firebase для своего проекта. Следуйте инструкциям по настройке приложения для Android. Убедитесь, что вы отправили письмо поддержки. В моем случае это была проблема, и, указав действительный адрес электронной почты, устраните проблему.
Это действительно было проблемой для меня. Код ошибки, безусловно, должен быть другим для такой ошибки. Большое спасибо :)
Пожалуйста, разместите свой журнал.