Firebase用户界面-Facebook,Google和电子邮件登录不起作用

时间:2019-03-09 17:07:05

标签: android facebook-login firebaseui

我在我的应用程序中使用firebase ui进行登录。 当我在调试模式下运行时,一切正常-完全没有错误。 我正在通过手机运行它,效果很好!

当我上传我的应用程序到商店时,我的问题开始了。 当用户尝试使用Facebook登录时,它告诉用户哈希密钥与任何存储的哈希都不匹配。 我在Facebook Developers和Android Studio中检查了几次,并检查了相同的哈希键。

当我尝试使用Google登录时,我也遇到“开发人员错误”。 我不知道为什么...

还有使用“电子邮件和密码”登录的错误-用户输入他的电子邮件和密码,没有任何反应。它只是停留在相同的活动上。

我不确定应该怎么做,应该创建SHA-1版本吗? 或这里我想念的其他东西。

这是我的登录代码

        public void startSignIn(){
    List<AuthUI.IdpConfig> providers = Arrays.asList(
            new AuthUI.IdpConfig.Builder(AuthUI.GOOGLE_PROVIDER)
                    .setPermissions(Arrays.asList(Scopes.PROFILE,Scopes.EMAIL)).build(),
            new AuthUI.IdpConfig.Builder(AuthUI.EMAIL_PROVIDER).build(),
            new AuthUI.IdpConfig.Builder(AuthUI.FACEBOOK_PROVIDER).build());
    Intent intent = AuthUI.getInstance()
            .createSignInIntentBuilder()
            .setAvailableProviders(providers).build();
    startActivityForResult(intent,RC_SIGN_IN);
}


protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);

    if(requestCode == RC_SIGN_IN){
        IdpResponse idpResponse = IdpResponse.fromResultIntent(data);
        if(idpResponse != null && resultCode == RESULT_OK){
            currentUser = FirebaseAuth.getInstance().getCurrentUser();

            //check if the user is exists by userUID. if he is, it jumps to main activity
            refToUsers.addValueEventListener(new ValueEventListener() {
                @Override
                public void onDataChange(DataSnapshot dataSnapshot) {
                    if(dataSnapshot.hasChild(currentUser.getUid())){

                        Intent mainActivity = new Intent(getApplicationContext(), MainActivity.class);
                        mainActivity.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TOP);
                        startActivity(mainActivity);
                    }else{
                        //if the user is not exists it will move to register activity
                        Intent registerActivity = new Intent(getApplicationContext(), RegisterActivity.class);
                        registerActivity.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TOP);
                        startActivity(registerActivity);
                    }
                }

                @Override
                public void onCancelled(DatabaseError databaseError) {
                    Log.d(TAG,databaseError.getMessage());
                }
            });



        }else if (idpResponse.getErrorCode() == ErrorCodes.NO_NETWORK) {
            errorToast("No internet connection");

        }else if (idpResponse.getErrorCode() == ErrorCodes.UNKNOWN_ERROR) {
            errorToast("Unknown Error");
        }
    }

简单的代码,但由于某些原因无法正常工作...

1 个答案:

答案 0 :(得分:0)

使用调试模式时,使用的签名密钥仅用于调试,它是调试登录密钥。对于已发布的应用,您的签名密钥应为Play控制台中使用的密钥。

如果您已成功将应用发布到Play商店,则您已经生成了所需的SHA-1证书指纹。而且,是的,它是发布的应用程序所必需的发布签名密钥。

以下是从 Google Play控制台获取所需签名密钥的方法:

  1. 登录到您的Google Play控制台。
  2. 从列表中选择您的应用。
  3. 在左侧菜单上,选择带有火箭图标的“发布管理”。
  4. 从展开的“发布管理”菜单中选择“应用签名”。
  5. 在“应用程序签名证书”部分,您将看到SHA1,SHA256和MD5证书指纹。复制所需的内容并使用它。

您还需要将此SHA1指纹添加到您的 Firebase控制台

  1. 登录到Firebase控制台。
  2. 选择您的Firebase项目。
  3. 转到“项目设置”左侧菜单上“项目概述”按钮旁边的齿轮图标。
  4. 在“常规”选项卡中,向下滚动到“您的应用程序”部分,其中列出了项目详细信息。您必须早些从这里下载google-services.json。
  5. 在此处添加您的发行版SHA1指纹。
  6. 下载 google-services.json 文件的新副本。
  7. 在您的项目中使用此较新的json文件,而不是较旧的json文件,因为您已更改Firebase配置,并且需要重新编译该应用程序。

希望这会有所帮助。

有用链接:

https://developer.android.com/studio/publish/app-signing

How to enable Google Play App Signing

相关问题