Ошибка проверки капчи Firebase и не позволяет пользователю пройти аутентификацию

#android #firebase #kotlin #firebase-authentication

#Android #firebase #kotlin #firebase-аутентификация

Вопрос:

Я понятия не имею, почему появляется эта ошибка. Когда я запускаю приложение на другом устройстве, приложение работает хорошо, но когда я сталкиваюсь с проблемой на другом устройстве. Также у меня проблема, когда я получаю доступ к firebase через Wi-Fi. Я связался со службой поддержки firebase, они говорят, что в ИНДИИ у них проблемы с сервером и интернет-провайдером

otpVerification.kt

 const val USER_REF:String="user"
class OtpVerification : AppCompatActivity() {


lateinit var  auth: FirebaseAuth

private var mAuthVerificationId: String? = null

private var mOtpText: EditText? = null
private var mVerifyBtn: Button? = null

private var mOtpProgress: ProgressBar? = null

private var mOtpFeedback: TextView? = null

lateinit var email:String
lateinit var password: String

private lateinit var database: DatabaseReference

lateinit  var uname:String


lateinit  var mCurrentUser: FirebaseUser
override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_otp_verification)


    mAuthVerificationId = intent.getStringExtra("AuthCredentials")
    Log.d("AuthCredentials", mAuthVerificationId.toString())

    email= intent.getStringExtra("email").toString()
    password= intent.getStringExtra("password").toString()
    uname= intent.getStringExtra("name").toString()

    mOtpFeedback = findViewById(R.id.otp_form_feedback)
    mOtpProgress = findViewById(R.id.otp_progress_bar)
    mOtpText = findViewById(R.id.otp_text_view)


    auth=Firebase.auth

    database = FirebaseDatabase.getInstance().reference


    mVerifyBtn = findViewById(R.id.verify_btn)

    mVerifyBtn?.setOnClickListener(View.OnClickListener {
        val otp = mOtpText?.text.toString()
        if (otp.isEmpty()) {
            mOtpFeedback?.visibility = View.VISIBLE
            mOtpFeedback?.text = "Please fill in the form and try again."
        } else {
            mOtpProgress?.visibility = View.VISIBLE
            mVerifyBtn?.isEnabled = false
            val credential = PhoneAuthProvider.getCredential(mAuthVerificationId!!, otp)
            signInWithPhoneAuthCredential(credential)
        }
    })
  }

  private fun signInWithPhoneAuthCredential(credential: PhoneAuthCredential) {
    auth?.signInWithCredential(credential)
            ?.addOnCompleteListener(this,
                    OnCompleteListener<AuthResult?> { task ->
                        if (task.isSuccessful) {

                            createAccount(email,password)
                            mCurrentUser= auth.currentUser!!
                            Prefs.put(this, mCurrentUser)
                            Log.d("user",mCurrentUser.toString())
                            sendUserToHome()
                            Log.d("TAG", "Task is succesful")
                            // ...
                        } else {
                            if (task.exception is FirebaseAuthInvalidCredentialsException) {
                                // The verification code entered was invalid
                                mOtpFeedback?.visibility = View.VISIBLE
                                mOtpFeedback?.text = "There was an error verifying OTP"
                            }
                        }
                        mOtpProgress?.visibility = View.INVISIBLE
                        mVerifyBtn?.isEnabled = true
                    })
 }


 fun sendUserToHome() {
    val intent = Intent(this, MainActivity::class.java)
    intent.flags = Intent.FLAG_ACTIVITY_NEW_TASK or Intent.FLAG_ACTIVITY_CLEAR_TASK
    startActivity(intent)
    finish()
}

private fun createAccount(email: String, password: String) {
    Log.d("TAG", "createAccount:${email.toString()}")
    //Log.d("TAG", "validate form is ${validateForm().toString()}")

    // [START create_user_with_email]
    auth.createUserWithEmailAndPassword(email, password)
            .addOnCompleteListener(this) { task ->
                if (task.isSuccessful) {
                    // Sign in success, update UI with the signed-in user's information
                    Log.d("TAG", "createUserWithEmail:success")
                    val user = auth.currentUser

                    Toast.makeText(baseContext, "Authentication Success $user", Toast.LENGTH_SHORT)
                            .show()
                    sendEmailVerification()

                    val intent = Intent(this, MainActivity::class.java)
                    intent.flags = Intent.FLAG_ACTIVITY_CLEAR_TOP
                    startActivity(intent)
                    Log.d("Delete", "deleting activity signup")

                    finish()

                } else {
                    // If sign in fails, display a message to the user.
                    Log.w("TAG", "createUserWithEmail:failure", task.exception)
                    Toast.makeText(
                            baseContext, "Authentication failed.",
                            Toast.LENGTH_SHORT
                    ).show()
                    //                   updateUI(null)
                }

                // [START_EXCLUDE]

                // [END_EXCLUDE]
            }
    // [END create_user_with_email]
createUSer()
}

private fun sendEmailVerification() {
           // Send verification email
    // [START send_email_verification]
    val user = auth.currentUser!!
    user.sendEmailVerification()
            .addOnCompleteListener(this) { task ->

                if (task.isSuccessful) {
                    Toast.makeText(baseContext,
                            "Verification email sent to ${user.email} ",
                            Toast.LENGTH_SHORT).show()

                    Log.d("TAG", "sendEmailVerification")
                } else {
                    Log.d("TAG", "sendEmailVerification", task.exception)
                    Toast.makeText(baseContext,
                            "Failed to send verification email.",
                            Toast.LENGTH_SHORT).show()
                }
                // [END_EXCLUDE]
            }
    // [END send_email_verification]
}

fun createUSer(){
    database.child(USER_REF).child(uname).child("email").setValue(email)
    Log.d("CREATED","create user" uname)
}


}
  

logcat

 2020-11-11 17:57:45.290 28364-28364/com.bva_valai_pada E/zza: Problem 
retrieving SafetyNet Token: 7: 
2020-11-11 17:57:45.358 28364-28364/com.bva_valai_pada W/ActivityThread: 
handleWindowVisibility: no activity for token android.os.BinderProxy@5308a64
2020-11-11 17:57:45.873 28364-30352/com.bva_valai_pada E/FirebaseAuth: 
[GetAuthDomainTask] Error getting project config. Failed with {
  "error": {
    "code": 400,
    "message": "INVALID_CERT_HASH",
    "errors": [
      {
        "message": "INVALID_CERT_HASH",
        "domain": "global",
        "reason": "invalid"
      }
    ]
  }
}
 400
2020-11-11 17:57:45.919 28364-28364/com.bva_valai_pada E/zza: Failed to get 
reCAPTCHA token - calling backend without app verification
2020-11-11 17:57:45.962 28364-28364/com.bva_valai_pada I/AssistStructure: 
Flattened final assist data: 4392 bytes, containing 1 windows, 13 views
2020-11-11 17:57:45.966 28364-28410/com.bva_valai_pada W/System: Ignoring 
header X-Firebase-Locale because its value was null.
2020-11-11 17:57:46.611 28364-28410/com.bva_valai_pada E/FirebaseAuth: 
[SmsRetrieverHelper] SMS verification code request failed: unknown status 
code: 17093 null
2020-11-11 17:57:46.621 28364-28364/com.bva_valai_pada D/Exception: 
com.google.firebase.auth.FirebaseAuthException: This request is missing a 
valid app identifier, meaning that neither SafetyNet checks nor reCAPTCHA 
checks succeeded. Please try again, or check the logcat for more details.
  

Комментарии:

1. Привет! Вы нашли какое-либо решение?

2. Да, я не добавил свой ключ SHA-1 в проект firebase, и после его добавления моя проблема была решена

Ответ №1:

Похоже, вам нужно добавить хэш сертификата SHA-1 к регистрации вашего приложения в консоли Firebase. Я думаю, вы можете найти инструкции для этого здесь

Ответ №2:

Ваша проблема связана с ключами SHA1 и SHA256. Вы должны добавить их для аутентификации своих сертификатов.

  • Элемент списка

  • Переход

    Консоль Firebase вашего проекта Настройка проекта аутентификации (кнопка Настройки рядом с обзором проекта) Добавить отпечаток пальца Добавьте значения SHA-1 и SHA-256 вашего хранилища ключей. Вы можете получить хранилища ключей из gradle следующим образом.

./gradlew signingReport

Прочитайте это для получения дополнительной информации: https://firebase.google.com/docs/auth/android/phone-auth#enable-app-verification

Комментарии:

1. Спасибо за ваши усилия, но я уже получил ответ и отметил его правильно

Ответ №3:

Шаг 1: Выберите проект.

Шаг 2. включите проверку устройства Android

Используйте ссылку ниже, чтобы включить проверку устройства Android.

https://console.cloud.google.com/apis/library/androidcheck.googleapis.com

введите описание изображения здесь

Ответ №4:

Вам нужно добавить отпечаток пальца в свой проект firebase, как показано ниже простым способом

  1. Перейдите в свою Android studio и откройте вкладку Gradle в правом углу.

  2. Ваше имя приложения> Запустить конфигурацию> .. [signingReport]> двойной щелчок введите описание изображения здесь

  3. Посмотрите на окно вашего терминала снизу и скопируйте строки SHA-1 и SHA-256

  4. Переход firebase.google.com > выберите свой проект > настройки проекта> общие

  5. Нажмите «Добавить отпечаток пальца» и вставьте скопированные ключи, не включая имя SHA-1 или SHA-256

  6. Нажмите добавить и повторно запустите приложение.

Комментарии:

1. SHA-1 и SHA-256 должны быть добавлены, чтобы избежать той же проблемы.

Ответ №5:

что сработало для меня, так это комбинация других ответов:
.. Включить проверку устройства Android для ответа от @Tippu Fisal Sheriff
.. получить ключи SHA-1 и SHA-256, выполнив ./ gradlew signingReport с терминала, папка Android для ответа от @Sarwar Ahmed и @Malcolm Deck
.. на веб-сайте firebase, перейдяк настройкам проекта и ответу «добавить отпечаток пальца» от @Sarwar Ahmed