簡體   English   中英

"Firebase 身份驗證在簽名的 APK 中不起作用"

[英]Firebase Authentication Not working in signed APK

我正在使用 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();

        }
    }
}

我遇到了同樣的問題,我使用這些方法解決了這個問題。

  1. 使用這些說明在 Play 商店控制台上完成應用簽名如何啟用 Google Play 應用簽名

  2. 轉到您的 Firebase 控制台設置 > 常規 > 您的應用 >(選擇您的項目),然后從您的 Play 商店添加來自應用簽名證書的 SHA-1。 您可以通過轉到發布管理 -> 應用簽名來獲取 SHA-1,如圖所示。

在此處輸入圖片說明

您在控制台中擁有指紋證書,但它僅用於調試目的,對於簽名的 apk,您需要一個生產指紋證書,您可以通過

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

找到 SHA-1 密鑰的步驟: 1) 轉到您的 Google Play 管理中心 2) 選擇目標應用 3) 轉到“版本管理”下的“應用簽名” 4) 可以在“應用簽名”下找到 SHA-1 密鑰證書”

我花了很多時間來解決這個問題,我希望這可以幫助遇到同樣問題的人。

對於 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

也許我有點晚了,但是對於遇到問題但沒有找到解決方案的每個人,這是我的:

我在 Firebase 上托管了我的應用程序,並為電子郵件和密碼啟用了 Firebase 身份驗證。

該應用程序在調試模式下運行良好,但是當我簽署該應用程序並在我的手機上運行它時,沒有API 工作。 我發現這是由於我在google-cloud中的api-key被限制了。 我發現我只使用了調試應用程序中的 SHA1,但是我還需要添加 SHA1 發布密鑰。

生成 SHA1 密鑰相當簡單:

  • 按照本教程為您的應用生成密鑰: Firebase 部署教程

  • 使用該密鑰生成您的 SHA1:

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

如果您收到無法找到命令“keystore”的錯誤,請導航到您的Java 運行時環境 (jre)目錄並在那里使用該命令。 可以在此處找到示例路徑:

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

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

直接從 Firebase 控制台有一個非常簡單的方法。

步驟 01:只需轉到Firebase 控制台中的設置>集成

在此處輸入圖片說明

步驟 02:然后點擊Google Play卡上的鏈接按鈕,將 Google Play 控制台中的SHA-1SHA-256代碼直接添加到 Firebase 控制台。

在此處輸入圖片說明

然后通過轉到設置>集成將其添加到您的 Firebase 控制台檢查中

在此處輸入圖片說明

步驟 03:在這里,您必須手動將上傳密鑰證書SHA-1從 Google Play 控制台手動添加到 firebase google play 控制台

在此處輸入圖片說明

步驟 04:然后下載新的google-services.json並將其替換為您在創建 Firebase 項目時添加的 Android Studio 中的那個。

對於任何新來的人,鑰匙被移到

Play 商店控制台 > 您的應用 > 發布 > 設置 > 應用完整性

在這里您會找到 SHA-1 和 SHA-256 密鑰,將它們添加到您的 firebase 項目中,您就可以了。

可以在Release > Setup > App Integrity<\/strong>下找到 SHA-1 證書指紋

接下來是在 Firebase 控制台中添加 SHA-1 證書指紋。 轉到項目設置 > 常規 > 添加指紋<\/strong>

執行以下操作后,我重新下載了新的 google-services.json 文件並替換了我項目中的那個。

至於我的情況。 完成上述步驟后,發布的應用仍然無法連接到 Firebase。 我所做的是在Google Cloud Platform > API and Services > Credentials<\/strong>中手動添加 SHA-1 證書指紋,然后選擇 Android 密鑰(由 Firebase 自動創建)。

您只需要在調試模式下找到調試 SHA1 和 SHA256 進行身份驗證

對於窗戶:

在 IDE 中打開終端:輸入:cd android

接着

畢業簽約報告

並復制調試 SHA1 和 SHA256 並將它們粘貼到 firebase 控制台

------------------對於簽名的apk ----------------------------- --

開放終端類型:

keytool-list-v-keystore"{你簽署apk的jks文件的路徑}" alias {用於簽署apk的keystore的別名}-storepass{keystore的密碼}-keypass{keystore的密碼}

您將獲得發布 SHA1 和 SHA256 將這兩者粘貼到 firebase 控制台

這會起作用

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM