更新
我的应用程序在实时应用程序中不断发生崩溃。每周有 100-200 次崩溃。所以我开始悬赏这个问题。如果有人解决了。请帮忙。
但是,99% 的用户都没有崩溃。这些崩溃可能会影响我的应用程序在 Play 商店中的 repo 。所以如果我没有得到解决方案,那么我最终将删除此功能以在 FirebaseAuth 中通过电子邮件/密码登录:/
问题:
我在 Android 应用程序 Firebase 身份验证登录中发生了多次崩溃(249 名用户发生了 295 次崩溃)。 1-2% 的用户尝试通过电子邮件密码登录时遇到此崩溃。我研究了这个错误并得到提示,当播放服务未运行时会发生这种情况 this answer.
仅供引用,google/Facebook 身份验证运行完美。此问题仅在通过电子邮件密码登录时出现。
我尝试了什么?
我试图在登录方法上放置一个 try-catch block 。并试图捕捉这个异常。作为解决方案,我想显示一个对话框,通知用户播放服务未运行。并且他可以手动打开play-store启动play-service,然后再访问这个。
但正如我在 Fabric 上看到的那样,崩溃永远不会出现在 catch block 中,并且当发生此异常时应用程序会崩溃。因为这个错误是在FirebaseAuth SDK中抛出的。
需要什么?
首先我想确定这个异常的原因。如果由于播放服务未运行而发生这种情况,那么我想向用户显示一个对话框。当前从未显示,并且在出现以下异常后崩溃。
Fatal Exception: com.google.android.gms.g.f: com.google.firebase.e: A network error (such as timeout, interrupted connection or unreachable host) has occurred.
at com.google.android.gms.tasks.zzu.getResult(Unknown Source)
at com.startech.dreamteam11.app.activities.ActivityLogin.tryLogin(Unknown Source)
at com.startech.dreamteam11.app.activities.ActivityLogin.lambda$-wlX6lv_j3Q0nUN9OuqzHS7ZGP4(Unknown Source)
at com.startech.dreamteam11.app.activities.-$$Lambda$ActivityLogin$-wlX6lv_j3Q0nUN9OuqzHS7ZGP4.onComplete(lambda)
at com.google.android.gms.tasks.zzj.run(Unknown Source)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:145)
at android.app.ActivityThread.main(ActivityThread.java:6946)
at java.lang.reflect.Method.invoke(Method.java)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1404)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1199)
代码
private void loginViaEmailPassword(String email, String pass) {
showProgressBar();
try {
// check if user is registered. then try login
FirebaseAuth.getInstance().fetchSignInMethodsForEmail(email).addOnCompleteListener(task -> {
SignInMethodQueryResult result = task.getResult();
if (task.isSuccessful() && result != null && result.getSignInMethods() != null && result.getSignInMethods().size() > 0) {
// user is registered, now try login
tryLogIn(email, pass, new OnFireBaseLogin() {
@Override
public void onSuccess(FirebaseUser user) {
// check if email is verified, if not send verification email.
if (user.isEmailVerified()) {
// user is verified, redirect to main screen
startMainActivity();
} else {
sendVerificationEmail(user, task1 -> {
hideProgressBar();
FirebaseAuth.getInstance().signOut();
if (task1.isSuccessful()) {
Utilities.getInstance().showDialog(ActivityLogin.this, getString(R.string.sent_verification_email), getString(R.string.msg_sent_verification_email), (dialog, which) -> {
dialog.dismiss();
});
} else {
errorMessage(getString(R.string.msg_error_sending_email));
}
});
}
}
@Override
public void onError(int error, @Nullable Throwable exception) {
hideProgressBar();
assert exception != null;
{
App.getInstance().logException(new Exception(exception), getClass());
errorMessage(exception.getMessage());
}
}
});
} else {
hideProgressBar();
errorMessage(getString(R.string.msg_email_not_registered));
}
});
} catch (Exception e) {
hideProgressBar();
App.getInstance().logException(e, getClass(), true);
Utilities.getInstance().showDialog(this, getString(R.string.some_error_occurred), getString(R.string.msg_fail_login_play_service)).show();
}
}
public void tryLogIn(String email, String pass) {
FirebaseAuth.getInstance().signInWithEmailAndPassword(email, pass).addOnCompleteListener(new OnCompleteListener<AuthResult>() {
@Override
public void onComplete(@NonNull Task<AuthResult> task) {
FirebaseUser currentUser = FirebaseAuth.getInstance().getCurrentUser();
if (task.isSuccessful() && currentUser != null) {
Log.w(TAG, "signInWithCustomToken:success", task.getException());
successResponse(currentUser);
} else {
Log.w(TAG, "signInWithCustomToken:failure", task.getException());
errorResponse(0, task.getException());
}
}
});
}
最佳答案
试试这段代码
bt.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (Validation.loginValidation(edtEmail, edtPass)) {
loginFirebase(edtEmail.getText().toString(), edtPass.getText().toString(), firebaseAuth);
}
}
});
public void loginFirebase(String email, String pass, FirebaseAuth firebaseAuth) {
progressDialog.setTitle("Please Wait.....");
progressDialog.setMessage("Processing....");
progressDialog.setCancelable(false);
progressDialog.show();
(firebaseAuth.signInWithEmailAndPassword(email, pass)).addOnCompleteListener(new OnCompleteListener<AuthResult>() {
@Override
public void onComplete(@NonNull Task<AuthResult> task) {
if (task.isSuccessful()) {
progressDialog.dismiss();
Toast.makeText(getActivity(), "Login Successful", Toast.LENGTH_LONG).show();
Intent i = new Intent(getActivity(), DrawerMain.class);
startActivity(i);
edtEmail.setText("");
edtPass.setText("");
} else {
Log.e("Error", task.getException().toString());
Toast.makeText(getActivity(), task.getException().getMessage(), Toast.LENGTH_LONG).show();
}
}
});
}
希望对您有所帮助!
谢谢。
关于android - Firebase 身份验证 - 发生网络错误(例如超时、连接中断或主机无法访问),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54971609/
我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我正在使用Sequel构建一个愿望list系统。我有一个wishlists和itemstable和一个items_wishlists连接表(该名称是续集选择的名称)。items_wishlists表还有一个用于facebookid的额外列(因此我可以存储opengraph操作),这是一个NOTNULL列。我还有Wishlist和Item具有续集many_to_many关联的模型已建立。Wishlist类也有:selectmany_to_many关联的选项设置为select:[:items.*,:items_wishlists__facebook_action_id].有没有一种方法可以
我使用的是Firefox版本36.0.1和Selenium-Webdrivergem版本2.45.0。我能够创建Firefox实例,但无法使用脚本继续进行进一步的操作无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055)错误。有人能帮帮我吗? 最佳答案 我遇到了同样的问题。降级到firefoxv33后一切正常。您可以找到旧版本here 关于ruby-无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055),我们在StackOverflow上找到一个类
我已经构建了一些serverspec代码来在多个主机上运行一组测试。问题是当任何测试失败时,测试会在当前主机停止。即使测试失败,我也希望它继续在所有主机上运行。Rakefile:namespace:specdotask:all=>hosts.map{|h|'spec:'+h.split('.')[0]}hosts.eachdo|host|begindesc"Runserverspecto#{host}"RSpec::Core::RakeTask.new(host)do|t|ENV['TARGET_HOST']=hostt.pattern="spec/cfengine3/*_spec.r
我有一个存储主机名的Ruby数组server_names。如果我打印出来,它看起来像这样:["hostname.abc.com","hostname2.abc.com","hostname3.abc.com"]相当标准。我想要做的是获取这些服务器的IP(可能将它们存储在另一个变量中)。看起来IPSocket类可以做到这一点,但我不确定如何使用IPSocket类遍历它。如果它只是尝试像这样打印出IP:server_names.eachdo|name|IPSocket::getaddress(name)pnameend它提示我没有提供服务器名称。这是语法问题还是我没有正确使用类?输出:ge
在启用Rack::Deflater来gzip我的响应主体时偶然发现了一些奇怪的东西。也许我遗漏了一些东西,但启用此功能后,响应被压缩,但是资源的ETag在每个请求上都会发生变化。这会强制应用程序每次都响应,而不是发送304。这在没有启用Rack::Deflater的情况下有效,我已经验证页面源没有改变。我正在运行一个使用thin作为Web服务器的Rails应用程序。Gemfile.lockhttps://gist.github.com/2510816有没有什么方法可以让我从Rack中间件获得更多的输出,这样我就可以看到发生了什么?提前致谢。 最佳答案
最近因为项目需要,需要将Android手机系统自带的某个系统软件反编译并更改里面某个资源,并重新打包,签名生成新的自定义的apk,下面我来介绍一下我的实现过程。APK修改,分为以下几步:反编译解包,修改,重打包,修改签名等步骤。安卓apk修改准备工作1.系统配置好JavaJDK环境变量2.需要root权限的手机(针对系统自带apk,其他软件免root)3.Auto-Sign签名工具4.apktool工具安卓apk修改开始反编译本文拿Android系统里面的Settings.apk做demo,具体如何将apk获取出来在此就不过多介绍了,直接进入主题:按键win+R输入cmd,打开命令窗口,并将路
在添加一些空格以使代码更具可读性时(与上面的代码对齐),我遇到了这个:classCdefx42endendm=C.new现在这将给出“错误数量的参数”:m.x*m.x这将给出“语法错误,意外的tSTAR,期待$end”:2/m.x*m.x这里的解析器到底发生了什么?我使用Ruby1.9.2和2.1.5进行了测试。 最佳答案 *用于运算符(42*42)和参数解包(myfun*[42,42])。当你这样做时:m.x*m.x2/m.x*m.xRuby将此解释为参数解包,而不是*运算符(即乘法)。如果您不熟悉它,参数解包(有时也称为“spl
所以我想到了这个,想知道当下面的一些事情完成后会发生什么。classTestdefself.abcattr_accessor:Johnendendobject=Test.newputs"beforecallingclassmethodabc:#{object.class.instance_methods(false)}"Test.abcputs"aftercallingclassmethodabc:#{object.class.instance_methods(false)}"这里我检查的是,getter和setter方法是否以这种方式创建。如果是这样,是那些实例方法或类方法。首先我创