为什么我的程序会返回Google登录12500错误?

时间:2018-10-30 06:13:45

标签: android google-api google-signin googlesigninapi

我正在尝试让Google登录以与我的应用一起使用。到目前为止,我认为我已经正确地完成了所有操作。我遵循了有关设置googlesigninclient的google文档的说明,可以使该应用进入登录按钮,但是当有人尝试登录时,它会返回12500错误(SIGN_IN_FAILED)。我已经正确设置了google api凭据,并且已经在我的debug.keystore中正确设置了Google api凭据,并且在我的应用文件夹中下载了certificate.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

4 个答案:

答案 0 :(得分:1)

对我来说是因为我启用了Google Play应用签名,所以您必须从发布管理-> 应用签名-> “应用签名证书” 部分

答案 1 :(得分:0)

只需将您的Google Play服务更新到最新版本。如果您使用的是AVD,则Nexus 5和5X图像均支持Google Play。模拟器启动并运行后,进入“扩展控件菜单”> Google Play,然后进行更新。

答案 2 :(得分:0)

错误代码10为DEVELOPER_ERROR: https://developers.google.com/android/reference/com/google/android/gms/common/api/CommonStatusCodes.html#DEVELOPER_ERROR

这几乎可以肯定意味着您没有在Google API控制台中正确注册SHA1和软件包名称: https://developers.google.com/identity/sign-in/android/start

如果您100%确保正确执行了此操作,请确保您的GoogleSignInOptions是正确的。特别是,请确保Web客户端ID(如果正在使用)与注册包名称和SHA1的项目属于同一项目。

答案 3 :(得分:0)

这可能是一个较晚的答案,但对某些人有帮助。为您的项目启用Firebase。请按照以下步骤设置Android应用。 确保您已提供支持电子邮件。在我的情况下,这是问题所在,并提供了有效的电子邮件,请解决该问题。