微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

onActivityResult: 传递结果 ResultInfo 失败

如何解决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 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?