- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我将我的 Firebase signInWithEmailAndPassword()
方法从我的登录 Activity 中移到了一个单独的网络包/类中。我已使用 createUserWithEmailAndPassword()
方法完成此操作,它按预期工作。但是,signInWithEmailAndPassword()
方法会抛出一个
java.lang.NullPointerException: Attempt to invoke virtual method 'com.google.android.gms.tasks.Task com.google.firebase.auth.FirebaseAuth.signInWithEmailAndPassword(java.lang.String, java.lang.String)' on a null object reference
在我的 FirebaseBacked.java
网络类的第 116 行抛出,该网络类由第 102 行的 LoginActivity.java
onClick()
启动。
我不确定如何从这里继续。非常感谢任何有关代码示例的帮助。
登录 Activity :
public class LoginActivity extends FirebaseBackend {
// UI references.
private ShowPassword inputPassword;
private AutoCompleteTextView inputEmail;
private FirebaseAuth auth;
private ProgressBar progressBar;
private Context context;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.context = this;
// Get Firebase auth instance
auth = FirebaseAuth.getInstance();
if (auth.getCurrentUser() != null) {
startActivity(new Intent(LoginActivity.this, MainActivity.class));
finish();
}
// Inflate interfaces
setContentView(R.layout.activity_login);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
inputEmail = (AutoCompleteTextView) findViewById(R.id.email);
inputPassword = (ShowPassword) findViewById(R.id.password);
progressBar = (ProgressBar) findViewById(R.id.progressBar);
Button btnSignup = (Button) findViewById(R.id.btn_signup);
Button btnLogin = (Button) findViewById(R.id.btn_login);
Button btnReset = (Button) findViewById(R.id.btn_reset_password);
btnSignup.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
startActivity(new Intent(LoginActivity.this, RegisterActivity.class));
}
});
btnReset.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
startActivity(new Intent(LoginActivity.this, ResetPasswordActivity.class));
}
});
btnLogin.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
String email = inputEmail.getText().toString();
final String password = inputPassword.getText().toString();
View focusView;
if (inputEmail.getText().length() == 0 || !android.util.Patterns.EMAIL_ADDRESS.matcher(email).matches()) {
inputEmail.setError(getString(R.string.error_invalid_email));
focusView = inputEmail;
focusView.requestFocus();
return;
}
if (!PasswordValidateUtility.isValidPassword(inputPassword.getText().toString().trim())) {
inputPassword.setError(getString(R.string.error_invalid_password));
focusView = inputPassword;
focusView.requestFocus();
return;
}
progressBar.setVisibility(View.VISIBLE);
signInWithMyApp();
}
});
}
}
Firebase后端
public class FirebaseBackend extends AppCompatActivity {
protected AutoCompleteTextView inputEmail;
protected ShowPassword inputPassword;
protected ProgressBar progressBar;
protected FirebaseAuth auth;
protected Context context;
public void createNewUser() {
String email = inputEmail.getText().toString().trim();
String password = inputPassword.getText().toString().trim();
progressBar.setVisibility(View.VISIBLE);
//create user
auth.createUserWithEmailAndPassword(email, password)
.addOnCompleteListener(FirebaseBackend.this, new OnCompleteListener<AuthResult>() {
@Override
public void onComplete(@NonNull Task<AuthResult> task) {
progressBar.setVisibility(View.GONE);
/**
* If creating the user in the FireBase backend fails, display a message
* to the user with a dialog. If sign in succeeds, the auth state listener
* will be notified and the logic to handle the signed in user can be
* handled by the listener.
*/
if (!task.isSuccessful()) {
/**
* FireBase failed creating the user on the backend. Most likely because
* the email address is already in use or there was a connection issue.
* We will show the user a `Failed Dialog` and ask them to try again.
*/
// Signup Failed Dialog
DialogChooser.failCreateUser(context);
} else {
/**
* The user was successfully created on the backend, so now ask FireBase
* to send an authentication email to the new user.
*/
sendVerificationEmail();
}
}
});
}
public void sendVerificationEmail() {
FirebaseUser user = FirebaseAuth.getInstance().getCurrentUser();
user.sendEmailVerification()
.addOnCompleteListener(new OnCompleteListener<Void>() {
@Override
public void onComplete(@NonNull Task<Void> task) {
if (!task.isSuccessful()) {
/**
* FireBase failed to send a verification email so we will show a
* `Failed Send Verification Dialog` to the user, sign out the user
* and override the pent.
*/
overridePendingTransition(0, 0);
FirebaseAuth.getInstance().signOut();
startActivity(getIntent());
DialogChooser.failSendVerification(context);
} else {
/**
* FireBase successfully sent a verification email so now we show a
* `Thank-you Dialog` to the user that allows them to check their email
* for the verification.
*/
DialogChooser.agreementAccepted(context);
FirebaseAuth.getInstance().signOut();
}
}
});
}
public void signInWithMyApp() {
String email = inputEmail.getText().toString();
final String password = inputPassword.getText().toString();
//Get Firebase auth instance - Just added
auth = FirebaseAuth.getInstance();
auth.signInWithEmailAndPassword(email, password)
.addOnCompleteListener(this, new OnCompleteListener<AuthResult>() {
@Override
public void onComplete(@NonNull Task<AuthResult> task) {
/**
* 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
*/
progressBar.setVisibility(View.GONE);
if (!task.isSuccessful()) {
/**
* If the user attempts to sign in with an account that is
* already in use, we'll show then a `FailSignIn Dialog` letting
* them know and give them the option to try with another email
* ID or signup with a new email address.
*/
DialogChooser.failSignIn(context);
} else {
// Check if the user has been verified.
checkIfEmailVerified();
}
}
});
}
public void checkIfEmailVerified() {
FirebaseUser user = FirebaseAuth.getInstance().getCurrentUser();
if (user.isEmailVerified()) {
/**
* If the user is verified, finish this activity and send them to the
* MainActivity and show a success toast message.
*/
Toast.makeText(this, getString(R.string.toast_login_success), Toast.LENGTH_SHORT).show();
Intent intent = new Intent(this, MainActivity.class);
this.startActivity(intent);
finish();
} else {
/**
* If the email is not verified, prompt a message to the user using
* the `failEmailVerified` dialog and make sure the user is still
* signed out.
*/
progressBar.setVisibility(View.GONE);
DialogChooser.failEmailVerified(context);
FirebaseAuth.getInstance().signOut();
}
}
}
最佳答案
Frank van Puffelen 的最后评论是一个有效的答案。您尚未在 FirebaseBackend
Activity 中实例化 auth
对象。
auth = FirebaseAuth.getInstance();
关于android - NullPointerException FirebaseAuth signInWithEmailAndPassword,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41966213/
我正在将我的模板代码移植到 XTend。在某些时候,我在测试用例中有这种类型的条件处理: @Test def xtendIfTest() { val obj = new FD if (
我是新来的 kotlin , 当我开始 Null Safety 时,我对下面的情况感到困惑. There's some data inconsistency with regard to initia
我的应用程序一直在各种Android版本中保持良好状态。我有用户在Android 4.3、5.0、5.1和6.0上正常运行。但是,具有S7 Edge的用户刚刚更新了Android 7.0,将文本粘贴到
我使用的是最新版本的 LWUIT (1.5)。我在资源编辑器中设计了我的表单,然后将代码生成到 netbeans。问题是如果我想访问除表单之外的任何对象,我会收到此错误: java.lang.Null
更新: 我在 Fedora 21 上运行它。 SonarQube - 5.0。 SonarQube Runner - 2.4 更新 2:Findbugs v3.1,Java 插件 v2.8 更新3:
RecupData 我的类仅在 web 中返回 NullPointerException。我连接到 pgsql db 8.3.7 - 该脚本在“控制台”syso 中运行良好 - 但引发了测试 Web
我在 mac 上使用 Processing 2.08。我正在尝试使用文档中给出的 createShape 函数创建 PShape。 PShape s; void setup(){ size(500
我在 mac 上使用 Processing 2.08。我正在尝试使用文档中给出的 createShape 函数创建 PShape。 PShape s; void setup(){ size(500
每次运行此 jsp 时,都会收到以下错误异常: org.apache.jasper.JasperException: java.lang.NullPointerException root cause
Kotlin 在编译时有一个出色的 null 检查,使用分离到“可空?”和“不可为空”的对象。它有一个 KAnnotator 来帮助确定来自 Java 的对象是否可以为空。但是,如果 not-null
我有一个布局将显示一个TextView,用于显示一个滴答时间。我遵循了此链接中的代码 How to Display current time that changes dynamically for
Elasticsearch 1.4.1版(“lucene_version”:“4.10.2”) 我有一个像这样的文件: $ curl 'http://localhost:9200/blog/artic
这是我从另一个类调用函数的方法Selenium 设置已定义。 public void Transfer() throws Exception { System.out.println("\nTrans
我试图在主类中使用我在此类中创建的函数,但它崩溃并显示“警告:无法在根 0 处打开/创建首选项根节点 Software\JavaSoft\Prefsx80000002。 Windows RegCrea
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 3 年前。 我有一个 Java 代码,它将
我声明了两张牌: Card card1 = new Card('3', Card.Suit.clubs); Card card2 = new Card('T', Card.Suit.diamonds)
我编写了一段代码来解码 Base64 图像并在 javafx 中表示该图像。在我的 url base64 代码中不断变化。这就是我在 javafx 代码中使用任务的原因。但我收到错误:java.lan
我正在尝试使用 arrayList 的 arrayList 在 Java 中实现图形。 每当调用 addEdge 函数时,我都会收到 NullPointerException 。我似乎无法弄清楚为什么
我是 Java/android 的新手,所以很多这些术语都是外国的,但我愿意学习。我不打算详细介绍该应用程序,因为我认为它不相关。我目前的问题是,我使用了博客中的教程和代码 fragment ,并使我
我正在开发一个 Android 应用程序来在 Android developer guide 的帮助下录制视频.我程序上的所有代码都与此页面相同。 我在 之外定义了权限标签。 当应
我是一名优秀的程序员,十分优秀!