【问题标题】:Firebase Authentication Not working in signed APKFirebase 身份验证在签名的 APK 中不起作用
【发布时间】:2017-04-13 09:04:56
【问题描述】:

我正在使用 Firebase Google 登录。它通过 USB 调试完美运行。但是当我生成签名的 APK 时,它停止工作。它无法登录。在 Android 5.1 和 Android 6.0.1 上使用它。此外,如果 Google Play 服务没有更新,它会提示用户更新它,因为哪个用户可能会离开应用程序。如何关闭提示并解决错误?

public class MainActivity extends AppCompatActivity implements  GoogleApiClient.OnConnectionFailedListener,
        View.OnClickListener {
private Button skip;
    private static final String TAG = "GoogleActivity";
    private static final int RC_SIGN_IN = 9001;
    private ProgressBar pb;
    // [START declare_auth]
    private FirebaseAuth mAuth;
    // [END declare_auth]

    // [START declare_auth_listener]
    private FirebaseAuth.AuthStateListener mAuthListener;
    // [END declare_auth_listener]

    private GoogleApiClient mGoogleApiClient;
    private TextView mStatusTextView;
    private TextView mDetailTextView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        pb=(ProgressBar)findViewById(R.id.signpro);
        pb.setVisibility(View.GONE);
        skip=(Button)findViewById(R.id.btnskip);
        skip.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                setContentView(R.layout.activity_home);
            }
        });
        // Views


        // Button listeners
        findViewById(R.id.sign_in_button).setOnClickListener(this);

        // [START config_signin]
        // Configure Google Sign In
        GoogleSignInOptions gso = new GoogleSignInOptions.Builder(GoogleSignInOptions.DEFAULT_SIGN_IN)
                .requestIdToken(getString(R.string.default_web_client_id))
                .requestEmail()
                .build();
        // [END config_signin]

        mGoogleApiClient = new GoogleApiClient.Builder(this)
                .enableAutoManage(this /* FragmentActivity */, this /* OnConnectionFailedListener */)
                .addApi(Auth.GOOGLE_SIGN_IN_API, gso)
                .build();

        // [START initialize_auth]
        mAuth = FirebaseAuth.getInstance();
        // [END initialize_auth]

        // [START auth_state_listener]
        mAuthListener = new FirebaseAuth.AuthStateListener() {
            @Override
            public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) {

                FirebaseUser user = firebaseAuth.getCurrentUser();
                if (user != null) {
                    // User is signed in
                    Log.d(TAG, "onAuthStateChanged:signed_in:" + user.getUid());
                    setContentView(R.layout.activity_home);

                } else {
                    // User is signed out
                    Log.d(TAG, "onAuthStateChanged:signed_out");
                }
                // [START_EXCLUDE]

                // [END_EXCLUDE]
            }
        };
        // [END auth_state_listener]
    }

    // [START on_start_add_listener]
    @Override
    public void onStart() {
        super.onStart();
        mAuth.addAuthStateListener(mAuthListener);

    }
    // [END on_start_add_listener]

    // [START on_stop_remove_listener]
    @Override
    public void onStop() {
        super.onStop();
        if (mAuthListener != null) {
            mAuth.removeAuthStateListener(mAuthListener);
        }
    }
    // [END on_stop_remove_listener]

    // [START onactivityresult]
    @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()) {
                Toast.makeText(this, "Signing you in. Please Wait...", Toast.LENGTH_LONG).show();
                // Google Sign In was successful, authenticate with Firebase
                GoogleSignInAccount account = result.getSignInAccount();
                firebaseAuthWithGoogle(account);
                Toast.makeText(this, "Sign In Successful!", Toast.LENGTH_SHORT).show();
            } else {
                // Google Sign In failed, update UI appropriately
                // [START_EXCLUDE]

                Toast.makeText(this, "Google Sign In failed. Please Skip.", Toast.LENGTH_SHORT).show();
                pb.setVisibility(View.GONE);
                // [END_EXCLUDE]
            }
        }
    }
    // [END onactivityresult]

    // [START auth_with_google]
    private void firebaseAuthWithGoogle(GoogleSignInAccount acct) {
        Log.d(TAG, "firebaseAuthWithGoogle:" + acct.getId());
        // [START_EXCLUDE silent]

        // [END_EXCLUDE]

        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(TAG, "signInWithCredential:onComplete:" + task.isSuccessful());

                        // 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(TAG, "signInWithCredential", task.getException());
                            Toast.makeText(MainActivity.this, "Authentication failed.",
                                    Toast.LENGTH_SHORT).show();
                        }
                        // [START_EXCLUDE]

                        // [END_EXCLUDE]
                    }
                });
    }
    // [END auth_with_google]

    // [START signin]
    private void signIn() {
        pb.setVisibility(View.VISIBLE);
        Intent signInIntent = Auth.GoogleSignInApi.getSignInIntent(mGoogleApiClient);
        startActivityForResult(signInIntent, RC_SIGN_IN);
    }
    // [END signin]



    @Override
    public void onConnectionFailed(@NonNull ConnectionResult connectionResult) {
        // An unresolvable error has occurred and Google APIs (including Sign-In) will not
        // be available.
        Log.d(TAG, "onConnectionFailed:" + connectionResult);
        Toast.makeText(this, "Google Play Services error.", Toast.LENGTH_SHORT).show();
    }

    @Override
    public void onClick(View v) {
        int i = v.getId();
        if (i == R.id.sign_in_button) {
            signIn();

        }
    }
}

【问题讨论】:

  • 对于签名的APK,你需要改变你的google-services.json!!
  • 更改您的 Google SHA-1 哈希以使用您的发布密钥库并更新 google-services.json。 !!
  • 从发布密钥中获取 SHA-1 并在谷歌控制台中更新。并且只有在你改变了包名的情况下才能得到google-services.json
  • 是的,您需要 google-services.json 来获取已签名的 apk
  • 非常感谢您的帮助。我的控制台中也已经包含 SHA1 证书指纹。在 google-services.json 中要改变什么?

标签: android firebase firebase-authentication google-signin


【解决方案1】:

您在控制台中有指纹证书,但它仅用于调试目的,对于签名的 apk,您需要生产指纹证书,您可以通过

 c:\Program Files\Java\jdk1.6.25\bin>keytool -list -v -keystore c:\you_key_here.key

【讨论】:

    【解决方案2】:

    我遇到了同样的问题,我用这些方法解决了这个问题。

    1. 使用这些说明在您的 Play 商店控制台上完成应用签名How to enable Google Play App Signing

    2. 转到您的 Firebase 控制台设置 > 常规 > 您的应用 >(选择您的项目),然后从您的 Play 商店添加来自 应用签名证书 的 SHA-1。您可以通过转到发布管理 -> 应用签名来获取 SHA-1,如图所示。

    【讨论】:

    • 我花了几个小时才解决这个问题。这应该包含在 firebase“在 Android 上使用 Google 登录进行身份验证”说明中。
    • keytool -list -v -keystore 和上面的东西有什么区别?
    • 这也是给我的。此散列不同于您从自己的密钥库中获得的 SHA-1。需要将此 SHA-1 与您的其他应用程序一起添加到您的 Firebase 应用程序允许的指纹中,以便您至少拥有 3 个(调试、发布、谷歌的)。 Google 对此签名证书的描述是“这是应用程序签名密钥的公共证书,Google 使用它来签署您的每个版本。使用它向 API 提供商注册您的密钥。应用程序签名密钥本身不可访问,并且被保留在安全的 Google 服务器上。”
    【解决方案3】:

    查找 SHA-1 密钥的步骤: 1) 转到您的 Google Play 控制台 2) 选择目标应用 3) 进入“发布管理”下的“应用签名” 4) SHA-1 密钥可以在“App Signing Certificate”下找到

    我花了好几个小时才解决这个问题,我希望这可以帮助遇到同样问题的人。

    【讨论】:

      【解决方案4】:

      对于 Windows:

      现实中:

      keytool -list -v -keystore "E:\Google Drive\MeshstocksSyncronize\AndroidKey\BRB\bangaliRussainBusiness.jks"
      

      例如:

      keytool -list -v -keystore "**Here is your path**"
      

      将此行粘贴到您的 android studio 终端中。

      观看视频以更好地理解: https://youtu.be/TYrmT8Emadg

      【讨论】:

        【解决方案5】:

        也许我有点晚了,但是对于遇到问题但没有找到解决方案的每个人,这里是我的:

        我在 Firebase 上托管了我的应用,并为电子邮件和密码启用了 Firebase 身份验证。

        该应用程序在调试模式下运行良好,但当我签署该应用程序并在我的手机上运行它时,NO API 工作正常。我发现这是由于我在 google-cloud 中的 api-key 受到限制。我发现我只使用了调试应用程序中的 SHA1,但是我还需要添加 SHA1 发布密钥。

        生成您的 SHA1 密钥相当简单:

        • 按照本教程为您的应用生成密钥:Firebase Deployment Tutorial

        • 使用该密钥生成您的 SHA1:

          keytool -list -v -keystore {keystore_name} -alias {alias_name}
          

        如果您收到无法找到命令“keystore”的错误消息,请导航到您的 Java 运行时环境 (jre) 目录并在其中使用该命令。可以在此处找到示例路径:

        C:\"Program Files"\Android\"Android Studio"\jre\bin
        

        【讨论】:

          【解决方案6】:

          Firebase 控制台方法有一些新的更新

          Firebase 控制台有一个非常简单的方法。

          步骤 01:只需转到 设置 > 集成 Firebase 控制台

          步骤 02:然后点击 Google Play 卡上的链接按钮,从您的 Google Play 控制台直接添加到您的 Firebase 控制台。

          然后它将被添加到您的 Firebase 控制台检查中,方法是转到 设置 > 集成

          步骤 03:在这里您必须手动将上传密钥证书 SHA-1 从 Google Play 控制台手动添加到 firebase google play 控制台

          步骤 04:然后下载新的google-services.json 并将其替换为您在 Android Studio 中创建 Firebase 项目时添加的那个。

          【讨论】:

            【解决方案7】:

            对于任何新来的人,钥匙都移到了

            Play 商店控制台 > 您的应用 > 发布 > 设置 > 应用完整性

            您将在此处找到 SHA-1 和 SHA-256 密钥,将它们添加到 你的firebase项目,你很好。

            【讨论】:

              【解决方案8】:

              SHA-1 证书指纹可在 Release > Setup > App Integrity

              下找到

              接下来是在 Firebase 控制台中添加 SHA-1 证书指纹。转到项目设置>常规>添加指纹

              执行以下操作后,我重新下载了新的 google-services.json 文件并替换了我项目中的那个。

              至于我的情况。完成上述步骤后,发布的应用仍然无法连接到 Firebase。我所做的是在 Google Cloud Platform > API and Services > Credentials 中手动添加 SHA-1 证书指纹,然后选择 Android 密钥(由 Firebase 自动创建)。

              【讨论】:

                猜你喜欢
                • 1970-01-01
                • 2018-09-30
                • 2019-03-30
                • 2020-12-15
                • 1970-01-01
                • 2020-07-16
                • 1970-01-01
                • 1970-01-01
                相关资源
                最近更新 更多