- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试使用 firebase 数据库系统在我的 android 项目中添加电话身份验证,但我遇到了“PhoneAuth Cardential”问题。它显示无法解析电话身份验证凭据,并且无法从外部包访问电话身份验证卡登蒂拉。我想使用发送给用户输入的联系电话号码的代码来验证用户身份,以便在身份验证后允许用户登录。
import android.app.ProgressDialog;
import android.content.Intent;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.text.TextUtils;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;
import com.google.android.gms.tasks.OnCompleteListener;
import com.google.android.gms.tasks.Task;
import com.google.firebase.FirebaseException;
import com.google.firebase.auth.AuthResult;
import com.google.firebase.auth.FirebaseAuth;
import com.google.firebase.auth.FirebaseAuthInvalidCredentialsException;
import com.google.firebase.auth.FirebaseUser;
import com.google.firebase.auth.PhoneAuthCredential;
import com.google.firebase.auth.PhoneAuthProvider;
import com.google.firebase.database.DataSnapshot;
import com.google.firebase.database.DatabaseError;
import com.google.firebase.database.DatabaseReference;
import com.google.firebase.database.FirebaseDatabase;
import com.google.firebase.database.ValueEventListener;
import com.rengwuxian.materialedittext.MaterialEditText;
import java.util.concurrent.TimeUnit;
public class Log_in extends AppCompatActivity {
private MaterialEditText phoneEditText;
private EditText editText;
private Button continueButton, sendCode;
private TextView mainTextView,miniTextVeiw;
private String phoneNumber;
private boolean phoneAndCode=false;
private String verificationID;
private PhoneAuthProvider.ForceResendingToken resendToken;
private FirebaseAuth firebaseAuth;
private PhoneAuthProvider.OnVerificationStateChangedCallbacks callbacksInstance;
private ProgressDialog progressDialog;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_log_in);
phoneEditText = (MaterialEditText) findViewById(R.id.phoneEditText);
continueButton = (Button) findViewById(R.id.continueButton);
editText = (EditText) findViewById(R.id.editText);
sendCode = (Button) findViewById(R.id.code);
mainTextView=findViewById(R.id.textView2);
miniTextVeiw=findViewById(R.id.textView3);
firebaseAuth = FirebaseAuth.getInstance();
sendCode.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
}
});
}
public void onContinueClick(View v) {
if(phoneAndCode==false)
{
if (phoneEditText.getText().toString() != null && phoneEditText.getText().toString().length() == 11) {
final DatabaseReference databaseReference = FirebaseDatabase.getInstance().getReference();
phoneNumber = phoneEditText.getText().toString();
phoneNumber="+92"+phoneNumber.substring(1);
progressDialog = new ProgressDialog(this);
progressDialog.setTitle("please wait");
progressDialog.setMessage("sending code");
progressDialog.setCancelable(false);
// phoneVerifier();
if (MainActivity.flag == 1) {
databaseReference.child("Driver").child(phoneNumber).setValue(null);
phoneVerifier();
} else if (MainActivity.flag == 0) {
// Toast.makeText(this,"called for driver and phone number is"+phoneNumber,Toast.LENGTH_SHORT).show();
databaseReference.child("Passenger").child(phoneNumber).setValue(null);
phoneVerifier();
}
phoneAndCode=true;
} else {
phoneEditText.setError("invalid phone number");
}
}
else if(phoneAndCode==true)
{
String verificationCode = null;
PhoneAuthCredential credential = null;
if (!(phoneEditText.getText().toString().equals(null))) {
verificationCode = phoneEditText.getText().toString();
credential = new PhoneAuthCredential(verificationID, verificationCode);
signInWithPhoneAuthCredential(credential);
} else
phoneEditText.setError("invalid verification code");
}
}
private void phoneVerifier() {
progressDialog.show();
callbacksInstance = new PhoneAuthProvider.OnVerificationStateChangedCallbacks() {
@Override
public void onVerificationCompleted(PhoneAuthCredential phoneAuthCredential) {
signInWithPhoneAuthCredential(phoneAuthCredential);
}
@Override
public void onVerificationFailed(FirebaseException e) {
Snackbar.make(findViewById(R.id.welcomeRoot), "invalid phone number", Snackbar.LENGTH_SHORT).show();
//if the phone number is wrong;
}
public void onCodeSent(String verificationId,
PhoneAuthProvider.ForceResendingToken token) {
// The SMS verification code has been sent to the provided phone number, we
// now need to ask the user to enter the code and then construct a credential
// by combining the code with a verification ID.
Snackbar.make(findViewById(R.id.welcomeRoot), "code sent", Snackbar.LENGTH_SHORT).show();
// Save verification ID and resending token so we can use them later
verificationID = verificationId;
resendToken = token;
progressDialog.dismiss();
// continueButton.setVisibility(View.INVISIBLE);
// sendCode.setVisibility(View.VISIBLE);
continueButton.setText("Send verification code");
mainTextView.setText("Enter verification code that you have recently received");
miniTextVeiw.setText("Enter verification code");
phoneEditText.setHint("enter verification code");
phoneEditText.setText(null);
// ...
}
};
PhoneAuthProvider.getInstance().verifyPhoneNumber(
phoneNumber, // Phone number to verify
60, // Timeout duration
TimeUnit.SECONDS, // Unit of timeout
this, // Activity (for callback binding)
callbacksInstance); // OnVerificationStateChangedCallbacks
}
private void signInWithPhoneAuthCredential(PhoneAuthCredential credential) {
firebaseAuth.signInWithCredential(credential)
.addOnCompleteListener(this, new OnCompleteListener<AuthResult>() {
@Override
public void onComplete(@NonNull Task<AuthResult> task) {
if (task.isSuccessful()) {
// Sign in success, update UI with the signed-in user's information
FirebaseUser user = task.getResult().getUser();
if (MainActivity.flag == 0) {
startActivity(new Intent(Log_in.this, DriverMapsActivity.class));
finish();
} else if (MainActivity.flag == 1) {
startActivity(new Intent(Log_in.this, CustomerMapsActivity.class));
finish();
}
// ...
} else {
// Sign in failed, display a message and update the UI
Toast.makeText(Log_in.this, "sign in failed try again", Toast.LENGTH_SHORT).show();
if (task.getException() instanceof FirebaseAuthInvalidCredentialsException) {
// The verification code entered was invalid
Toast.makeText(Log_in.this, "You have enterd an INVALID CODE", Toast.LENGTH_SHORT).show();
}
}
}
});
}
}
最佳答案
你应该试试这条线
credential =PhoneAuthProvider.getCredential(verificationID,verificationCode);
代替
credential = new PhoneAuthCredential(verificationID, verificationCode);
关于android - 无法从包裹外部访问 Phone Auth Cardential,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55512474/
主要问题是可以从已保存的 Auth 对象设置零 Auth 对象: let oldAuth = Auth.auth().currentUser let oldAuthId = Auth.auth().c
何时使用 this.afAuth.auth.signInWithCredential 在我的 Ionic 应用程序中一切正常。我可以使用 Google 身份验证登录并将用户个人资料推送到 fireba
我想在启动时使用我的测试用户帐户预加载 firebase auth 模拟器,就像我对 Firestore 模拟器及其导入/导出选项所做的一样。我尝试在模拟器运行时使用 auth:import 和 au
我正在尝试通过创建 Firebase DataService 来 DRY 我的应用程序,但我不知道为 Auth.auth() 转换什么类型。我查看了源代码定义,但它在我不理解的 Objective C
我有一个更新用户个人资料图片的组件:。我有第二个组件检测用户状态的变化:。问题是,在执行updateProfile()之后,没有触发auth.onAuthStateChanged()。因此,我得到了老
我正在使用 Facebook Javascript SDK,并且正在调整我网站的用户登录系统。我想知道 auth.login/auth.logout 和 auth.sessionChange 之间有什
目前,我正在完成Daniel Kehoe的Learn Ruby on Rails教程。练习之一是使用Google的Gmail帐户从“联系人”页面发送联系人表格。 但是,当我发送联系表格时,没有在邮箱中
我在我的应用中使用 Firebase Auth。我更新电子邮件如下: firebaseAuth.currentUser?.updateEmail(email) 电子邮件正在 100% 更新(必要时我也
在我的应用程序中,当我第一次让用户加入时,我会让他们登录并确认这有效,并且他们会获得一个用户 ID。但稍后在我的 Storyboard 中,我调用了 Auth.auth.currentUser.uid
我是编程新手,我正在尝试从 firebase 数据库中读取数据。我从 Firebase 手册中得到这段代码,我想知道术语 uid,AUTH.auth() 在这里是什么意思。它是一个变量吗?我从 fir
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 我们不允许提出有关书籍、工具、软件库等方面的建议的问题。您可以编辑问题,以便用事实和引用来回答它。 关闭
背景 我构建了一个连接到 Authorize.net 支付网关的电子商务应用程序。管理员可以通过以下方式处理信用卡: 管理员立即从客户的信用卡中扣款的“捕获”交易。 “仅授权”交易,管理员从信用卡中授
我正在使用 dj-rest-auth ( https://dj-rest-auth.readthedocs.io/en/latest/ ) 并尝试实现自定义注册表单。当我尝试注册新用户时,我有基本表单
我们正在使用 Azure Web App Easy Auth,并使用 Web App 作为反向代理,将流量转发到 Angular 应用程序。 角度应用程序使用/.auth/me 并使用 token 并
我有一个 Controller 和一个如下所示的 View ,它在一段时间内工作完美,但是在向服务器发出一些请求后(即每秒重新加载一次),它将在此行失败 if (!$this->tank_auth-
我希望在单个 Web 应用程序中,部分部分使用身份验证,部分部分完全开放(或者更具体地说,不使用基于容器的身份验证)。 使用基于容器的身份验证的应用程序部分位于 URL /而打开的部分位于 URL /
只要我按下按钮调用 signOut 方法,当前 View Controller 就会被关闭。但是,注销过程是成功的。 (我正在使用 FirebaseAuth SDK。) 这是我的代码: @IBActi
对于Firebase iOS,如果我想做用户认证,这3个选择有什么区别吗? FirebaseUI FirebaseUI/授权 Firebase/授权 如果有人可以解释使用“预构建”FirebaseUI
我正在使用 Vue-auth 包来验证我的 vue-cli 应用程序。一切正常,但当我在我的 vue 操作中访问此代码时,它返回 undefined。有什么想法吗? const AuthService
所以我正在使用 Laravel 身份验证,第一次它工作正常,但删除 Auth 文件夹后,我再次运行 php artisan make:auth 但它不会创建另一个 Auth 文件夹。 View 和模型
我是一名优秀的程序员,十分优秀!