如何解决onActivityResult: 传递结果 ResultInfo 失败
我正在尝试在我的登录活动中设置 google 登录,但在 onActivityResult 上出现此错误
java.lang.RuntimeException: Failure delivering result ResultInfo{who=null,request=9001,result=-1,data=Intent { (has extras) }}
我检查并尝试了许多针对此错误的解决方案,这些解决方案发布在其他问题上,但根本没有帮助!
这里是我如何在我的活动课上使用它
private lateinit var googleSignInClient: GoogleSignInClient
val gso = GoogleSignInoptions.Builder(GoogleSignInoptions.DEFAULT_SIGN_IN)
.requestIdToken(GOOGLE_CLIENT_ID)
.requestemail()
.build()
googleSignInClient = GoogleSignIn.getClient(this,gso)
startActivityForResult(googleSignInClient.signInIntent!!,RC_SIGN_IN)
这是活动结果
override fun onActivityResult(requestCode: Int,resultCode: Int,data: Intent?) {
super.onActivityResult(requestCode,resultCode,data)
if (resultCode!=RESULT_CANCELED){
if (requestCode == RC_SIGN_IN && data!=null) {
Log.d(TAG,"onActivityResult $mPresenter : $requestCode : $resultCode : $data")
mPresenter!!.result(requestCode,data) // line of the error 73
}
}
}
这里是错误的完整日志
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.googlemvp.signin,PID: 11583
java.lang.RuntimeException: Failure delivering result ResultInfo{who=null,data=Intent { (has extras) }} to activity {com.googlemvp.signin/com.googlemvp.signin.ui.LoginActivity}: java.lang.NullPointerException
at android.app.ActivityThread.deliverResults(ActivityThread.java:4846)
at android.app.ActivityThread.handleSendResult(ActivityThread.java:4887)
at android.app.servertransaction.ActivityResultItem.execute(ActivityResultItem.java:51)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2017)
at android.os.Handler.dispatchMessage(Handler.java:107)
at android.os.Looper.loop(Looper.java:214)
at android.app.ActivityThread.main(ActivityThread.java:7397)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:935)
Caused by: java.lang.NullPointerException
at c.d.a.a.a.d.a(:66)
at c.d.a.a.a.e.f(:34)
at com.googlemvp.signin.ui.LoginActivity.onActivityResult(:73)
at android.app.Activity.dispatchActivityResult(Activity.java:8110)
at android.app.ActivityThread.deliverResults(ActivityThread.java:4839)
这里的日志中 onActivityResult 中的数据根本不为空
LoginActivity: onActivityResult c.d.a.a.a.e@97eb6e3 : 9001 : -1 : Intent { (has extras) }
这里是presenter中的result方法和interactor类中的附加方法
// in presenter class
override fun result(requestCode: Int,data: Intent?) {
mInteractor!!.performResult(requestCode,data)
}
// in interactor class
override fun performResult(requestCode: Int,data: Intent?) {
if (requestCode == RC_SIGN_IN) {
val task = GoogleSignIn.getSignedInAccountFromIntent(data)
try {
// Google Sign In was successful,authenticate with Firebase
val account = task.getResult(ApiException::class.java)!!
mListener!!.onStart(account.idToken!!)
} catch (e: ApiException) {
// Google Sign In Failed,update UI appropriately
mListener!!.onFailure(e)
// Log.w(TAG,"Google sign in Failed",e)
}
}
}
解决方法
一般而言,您不应在代码中使用 !!
。选择双感叹号是为了对你尖叫,就像在 don't use it!!
中一样。当您使用 !!
时,您基本上是在禁用 Kotlin 最好的功能之一 - 空安全。
但就您而言,这不是问题的根源。
正如我们在日志中看到的,您有一个 mPresenter 实例,引用为 c.d.a.a.a.e@97eb6e3
然后在崩溃日志中我们看到
Caused by: java.lang.NullPointerException
at c.d.a.a.a.d.a(:66)
at c.d.a.a.a.e.f(:34)
at com.googlemvp.signin.ui.LoginActivity.onActivityResult(:73)
请注意,通话记录从下到上从您的活动第 73 行开始,我们进入 mPresenter
第 34 行,然后转到其他类 c.d.a.a.a.d.a
第 66 行,其中实际的 {{1} } 发生。
您应该遵循此日志并修复第三个类中的空问题。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。