首页 > 解决方案 > 使用协程在 Android BillingClient 中崩溃

问题描述

我收到通知,我的计费解决方案以一种奇怪的方式崩溃。我无法重现它或找到修复/绕过问题。也许你能帮上忙。

Fatal Exception: java.lang.IllegalStateException: Already resumed at kotlin.coroutines.SafeContinuation.resumeWith + 45(SafeContinuation.java:45) at com.android.billingclient.api.BillingClientKotlinKt$querySkuDetails$2$1.onSkuDetailsResponse + 2(BillingClientKotlinKt.java:2) at com.android.billingclient.api.zzj.run + 8(zzj.java:8) at android.os.Handler.handleCallback + 907(Handler.java:907) at android.os.Handler.dispatchMessage + 105(Handler.java:105) at android.os.Looper.loop + 216(Looper.java:216) at android.app.ActivityThread.main + 7625(ActivityThread.java:7625) at java.lang.reflect.Method.invoke(Method.java) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run + 524(RuntimeInit.java:524) at com.android.internal.os.ZygoteInit.main + 987(ZygoteInit.java:987)

//billing
implementation 'com.android.billingclient:billing:2.2.0'
implementation 'com.android.billingclient:billing-ktx:2.1.0'

标签: androidkotlin-coroutinesplay-billing-library

解决方案


自上周以来,我们运行此代码以防止异常:

suspend fun BillingClient.querySkuDetailsFixed(params: SkuDetailsParams) = suspendCancellableCoroutine<SkuDetailsResult> { continuation ->
querySkuDetailsAsync(params) { billingResult, skuDetails: List<SkuDetails>? ->
    if (continuation.isActive) {
        // doing some logging
        continuation.resumeWith(Result.success(SkuDetailsResult(billingResult, skuDetails)))
    } else {
      // Already resumed, doing some logging
    }
}
}

在日志中,我们看到我们从库中获得了 2 个调用:

第一个响应始终具有 BillingResponseCode -3 SERVICE_TIMEOUT

第二个响应通常有 6ERROR或 2 SERVICE_UNAVAILABLE

在我们的例子中,当应用程序在后台被唤醒时,就会发生这种情况PeriodicWorkRequest


推荐阅读