Cat*_*ail 5 android play-billing-library kotlin-coroutines
我收到通知,我的 Billing 解决方案以一种奇怪的方式崩溃。我无法重现它或找到修复/绕过问题。也许你可以帮忙。
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'
Run Code Online (Sandbox Code Playgroud)
自上周以来,我们运行此代码来防止异常:
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
}
}
}
Run Code Online (Sandbox Code Playgroud)
在日志中我们看到我们从库中收到了 2 个调用:
第一个响应始终具有 BillingResponseCode -3 SERVICE_TIMEOUT。
第二个响应通常为 6ERROR或 2 SERVICE_UNAVAILABLE。
在我们的例子中,当应用程序在后台唤醒时,就会发生这种情况PeriodicWorkRequest。