Телефонная аутентификация Firebase не работает после создания подписанного APK - PullRequest
4 голосов
/ 08 мая 2020

Мое приложение работало оштрафовано, пока я не сгенерировал подписанный APK в Android Studio, когда я выполняю аутентификацию на подписанном Apk, он просто показывает мне тост «не удается проверить телефон и создать учетную запись». Он отлично работал в режиме отладки. И когда я сделал отладочный APK, он также отлично работал в нем, но не в подписанном APK. Я не могу понять, что вызывает эту ошибку: аутентификация не работает только в подписанном APK

Мой код

   public class Register2 extends AppCompatActivity {

    FirebaseAuth auth;
    DatabaseReference reference;

    String otpCode;
    String verificationId;
    MaterialEditText phone, optEnter;
    Button next;
    CountryCodePicker countryCodePicker;

    PhoneAuthCredential credential;
    Boolean verificationOnProgress = false;
    ProgressBar progressBar;
    TextView resend;

    PhoneAuthProvider.ForceResendingToken token;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_register2);

        phone = findViewById(R.id.phone);
        optEnter = findViewById(R.id.codeEnter);
        countryCodePicker = findViewById(R.id.ccp);
        next = findViewById(R.id.nextBtn);
        auth = FirebaseAuth.getInstance();
        progressBar = findViewById(R.id.progressBar);
        resend = findViewById(R.id.resendOtpBtn);

        resend.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                // todo:: resend OTP
            }
        });

        next.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

                if (!phone.getText().toString().isEmpty() && phone.getText().toString().length() == 10) {
                    if (!verificationOnProgress) {
                        next.setEnabled(false);
                        String phoneNum = "+" + countryCodePicker.getSelectedCountryCode() + phone.getText().toString();
                        Log.d("phone", "Phone No.: " + phoneNum);
                        progressBar.setVisibility(View.VISIBLE);
                        requestPhoneAuth(phoneNum);
                    } else {
                        next.setEnabled(false);
                        optEnter.setVisibility(View.GONE);
                        progressBar.setVisibility(View.VISIBLE);
                        otpCode = optEnter.getText().toString();
                        if (otpCode.isEmpty()) {
                            optEnter.setError("Required");
                            return;
                        }

                        credential = PhoneAuthProvider.getCredential(verificationId, otpCode);
                        verifyAuth(credential);
                    }

                } else {
                    phone.setError("Valid Phone Required");
                }
            }
        });
    }

    private void requestPhoneAuth(String phoneNumber) {
        PhoneAuthProvider.getInstance().verifyPhoneNumber(phoneNumber, 60L, TimeUnit.SECONDS, this,
                new PhoneAuthProvider.OnVerificationStateChangedCallbacks() {

                    @Override
                    public void onCodeAutoRetrievalTimeOut(String s) {
                        super.onCodeAutoRetrievalTimeOut(s);
                        Toast.makeText(Register2.this, "OTP Timeout, Please Re-generate the OTP Again.", Toast.LENGTH_SHORT).show();
                        resend.setVisibility(View.VISIBLE);
                    }

                    @Override
                    public void onCodeSent(String s, PhoneAuthProvider.ForceResendingToken forceResendingToken) {
                        super.onCodeSent(s, forceResendingToken);
                        verificationId = s;
                        token = forceResendingToken;
                        verificationOnProgress = true;
                        progressBar.setVisibility(View.GONE);
                        next.setText("Verify");
                        next.setEnabled(true);
                        optEnter.setVisibility(View.VISIBLE);
                    }

                    @Override
                    public void onVerificationCompleted(PhoneAuthCredential phoneAuthCredential) {


                        verifyAuth(phoneAuthCredential);


                    }

                    @Override
                    public void onVerificationFailed(FirebaseException e) {
                        Toast.makeText(Register2.this, e.getMessage(), Toast.LENGTH_SHORT).show();

                    }
                });
    }


    private void verifyAuth(PhoneAuthCredential credential) {
        auth.signInWithCredential(credential).addOnCompleteListener(new OnCompleteListener<AuthResult>() {
            @Override
            public void onComplete(@NonNull Task<AuthResult> task) {
                if (task.isSuccessful()) {

                    Toast.makeText(Register2.this, "Phone Verified", Toast.LENGTH_SHORT).show();

                    FirebaseUser firebaseUser = auth.getCurrentUser();
                    String userid = firebaseUser.getUid();
                    reference = FirebaseDatabase.getInstance().getReference().child("UserIds").child(userid);
                    reference.setValue(true);


                    //checkUserProfile();


                } else {
                    progressBar.setVisibility(View.GONE);
                    Toast.makeText(Register2.this, "Can not Verify phone and Create Account.", Toast.LENGTH_SHORT).show();
                }
            }
        });
    }

    @Override
    protected void onStart() {
        super.onStart();

        if (auth.getCurrentUser() != null) {
            progressBar.setVisibility(View.VISIBLE);

            checkUserProfile();
        }
    }


    private void checkUserProfile() {


        Intent intent = new Intent(Register2.this, Details3.class);
        startActivity(intent);

    }

}

Ответы [ 2 ]

2 голосов
/ 08 мая 2020

После загрузки приложения в Google Play Store вам необходимо обновить отпечаток SHA-1 / SHA-255 в firebase. Вы найдете SHA-1 / SHA-255 в игровом магазине, как указано.

  1. Перейдите в Google Play Console и войдите
  2. Выберите приложение вы подписываете
  3. Go на Управление выпусками > Подписание приложения
  4. Скопируйте / загрузите отпечаток сертификата SHA-1 или SHA-256 из раздел сертификата подписи приложения

Screenshot

Теперь добавьте SHA-1 / SHA-255 в firebase, и ваше приложение снова вернется .

1 голос
/ 08 мая 2020

Вы добавили свое приложение Отпечаток SHA-1 в Firebase Console если нет, перейдите по этой ссылке .

...