Пользователь входит в мобильный телефон. num с помощью средства выбора кода страны во 2-м действии, а затем отправляется OTP, пользователь вводит полученный OTP в 3-м действии, вводит имя пользователя в 4-м действии. Если otp проверен и перенаправлен на так называемый главный экран.
Я использовал «+911234567890» в качестве тестового номера телефона с otp «111111», и когда я тестирую его в своем приложении, все работает совершенно нормально, все тосты и код.
Но когда я попытался запустить приложение с реальным моим собственным номером телефона «+919811226XXX», затем в активности LoginOTP я получил тост о том, что произошла внутренняя ошибка Firebase [BILLING_NOT_ENABLED], в Интернете я не смог найти никаких решений, некоторые говорили, что нужно активировать какой-то премиальный план для большего количества смс в день, но у меня также есть бесплатный ограничение в 10 смс в день, я не использовал ни одного из них, тогда почему возникает эта ошибка, некоторые говорят, что нужно включить платежную учетную запись Google Cloud, но для этого мне нужен кредит данные карты и все такое, чего у меня, будучи ребенком и студентом, нет, ни денег, ни карты, ни какого-либо другого поддающегося проверке способа оплаты.
Вот мой LoginPhoneNumberActivity.java
Код: Выделить всё
package com.example.pchat;
public class LoginPhoneNumberActivity extends AppCompatActivity {
CountryCodePicker countryCodePicker;
EditText phoneInput;
Button sendOtpBtn;
ProgressBar progressBar;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
EdgeToEdge.enable(this);
setContentView(R.layout.activity_login_phone_number);
ViewCompat.setOnApplyWindowInsetsListener(findViewById(R.id.phone_login_screen), (v, insets) -> {
Insets systemBars = insets.getInsets(WindowInsetsCompat.Type.systemBars());
v.setPadding(systemBars.left, systemBars.top, systemBars.right, systemBars.bottom);
return insets;
});
countryCodePicker = findViewById(R.id.login_countrycode);
phoneInput = findViewById(R.id.login_mobile_number);
sendOtpBtn = findViewById(R.id.send_otp_btn);
progressBar = findViewById(R.id.login_progress_bar);
progressBar.setVisibility(View.GONE);
countryCodePicker.registerCarrierNumberEditText(phoneInput);
sendOtpBtn.setOnClickListener((v)->{
if(!countryCodePicker.isValidFullNumber()){
phoneInput.setError("Phone number not valid");
return;
}
Intent intent = new Intent(LoginPhoneNumberActivity.this,LoginOtpActivity.class);
intent.putExtra("phone",countryCodePicker.getFullNumberWithPlus());
startActivity(intent);
});
}
}
Код: Выделить всё
package com.example.pchat;
public class LoginOtpActivity extends AppCompatActivity {
String phoneNumber;
Long timeoutSeconds = 60L;
String verificationCode;
PhoneAuthProvider.ForceResendingToken resendingToken;
EditText otpInput;
Button nextBtn;
ProgressBar progressBar;
TextView resendOtpTextView;
FirebaseAuth mAuth = FirebaseAuth.getInstance();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
EdgeToEdge.enable(this);
setContentView(R.layout.activity_login_otp);
ViewCompat.setOnApplyWindowInsetsListener(findViewById(R.id.login_otp_activity), (v, insets) -> {
Insets systemBars = insets.getInsets(WindowInsetsCompat.Type.systemBars());
v.setPadding(systemBars.left, systemBars.top, systemBars.right, systemBars.bottom);
return insets;
});
otpInput = findViewById(R.id.login_otp);
nextBtn = findViewById(R.id.login_next_btn);
progressBar = findViewById(R.id.login_progress_bar);
resendOtpTextView = findViewById(R.id.resend_otp_textview);
phoneNumber = Objects.requireNonNull(getIntent().getExtras()).getString("phone");
sendOtp(phoneNumber,false);
nextBtn.setOnClickListener(v -> {
String enteredOtp = otpInput.getText().toString();
PhoneAuthCredential credential = PhoneAuthProvider.getCredential(verificationCode,enteredOtp);
signIn(credential);
});
resendOtpTextView.setOnClickListener((v)->{
sendOtp(phoneNumber,true);
});
}
void sendOtp(String phoneNumber,boolean isResend){
startResendTimer();
setInProgress(true);
PhoneAuthOptions.Builder builder =
PhoneAuthOptions.newBuilder(mAuth)
.setPhoneNumber(phoneNumber)
.setTimeout(timeoutSeconds, TimeUnit.SECONDS)
.setActivity(this)
.setCallbacks(new PhoneAuthProvider.OnVerificationStateChangedCallbacks() {
@Override
public void onVerificationCompleted(@NonNull PhoneAuthCredential phoneAuthCredential) {
AndroidUtil.showToast(getApplicationContext(), "OTP verified successfully!");
signIn(phoneAuthCredential);
setInProgress(false);
}
@Override
public void onVerificationFailed(@NonNull FirebaseException e) {
String Fexceptions = e.getMessage();
AndroidUtil.showToast(getApplicationContext(), Fexceptions);
setInProgress(false);
}
@Override
public void onCodeSent(@NonNull String s, @NonNull PhoneAuthProvider.ForceResendingToken forceResendingToken) {
super.onCodeSent(s, forceResendingToken);
verificationCode = s;
resendingToken = forceResendingToken;
AndroidUtil.showToast(getApplicationContext(),"OTP sent successfully!");
setInProgress(false);
}
});
if(isResend){
PhoneAuthProvider.verifyPhoneNumber(builder.setForceResendingToken(resendingToken).build());
}else{
PhoneAuthProvider.verifyPhoneNumber(builder.build());
}
}
void setInProgress(boolean inProgress){
if(inProgress){
progressBar.setVistoibility(View.VISIBLE);
nextBtn.setVisibility(View.GONE);
}else{
progressBar.setVisibility(View.GONE);
nextBtn.setVisibility(View.VISIBLE);
}
}
void signIn(PhoneAuthCredential phoneAuthCredential){
//login and go to next activity
setInProgress(true);
mAuth.signInWithCredential(phoneAuthCredential).addOnCompleteListener(new OnCompleteListener() {
@Override
public void onComplete(@NonNull Task task) {
setInProgress(false);
if(task.isSuccessful()){
Intent intent = new Intent(LoginOtpActivity.this,LoginUsernameActivity.class);
intent.putExtra("phone",phoneNumber);
startActivity(intent);
finish();
}else{
AndroidUtil.showToast(getApplicationContext(),"OTP verification failed");
}
}
});
}
void startResendTimer(){
resendOtpTextView.setEnabled(false);
Timer timer = new Timer();
timer.schedule(new TimerTask() {
@SuppressLint("DefaultLocale")
@Override
public void run() {
timeoutSeconds--;
resendOtpTextView.setText(String.format("Resend OTP after %d seconds", timeoutSeconds));
if(timeoutSeconds {
resendOtpTextView.setEnabled(true);
});
}
}
},0,1000);
}
}
Код: Выделить всё
package com.example.pchat;
public class LoginUsernameActivity extends AppCompatActivity {
EditText usernameInput;
Button letMeInBtn;
ProgressBar progressBar;
String phoneNumber;
UserModel userModel;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
EdgeToEdge.enable(this);
setContentView(R.layout.activity_login_username);
ViewCompat.setOnApplyWindowInsetsListener(findViewById(R.id.login_username_activity), (v, insets) -> {
Insets systemBars = insets.getInsets(WindowInsetsCompat.Type.systemBars());
v.setPadding(systemBars.left, systemBars.top, systemBars.right, systemBars.bottom);
return insets;
});
usernameInput = findViewById(R.id.login_username);
letMeInBtn = findViewById(R.id.login_let_me_in_btn);
progressBar =findViewById(R.id.login_progress_bar);
phoneNumber = Objects.requireNonNull(getIntent().getExtras()).getString("phone");
getUsername();
letMeInBtn.setOnClickListener((v -> {
setUsername();
}));
}
void setUsername(){
String username = usernameInput.getText().toString();
if(username.isEmpty() || username.length()
Подробнее здесь: [url]https://stackoverflow.com/questions/79152144/firebase-phone-authentication-test-num-working-but-real-phone-num-showing-billi[/url]