在 Flutter 中从 Play 商店获取产品时,应用内购买崩溃
2022-09-02 10:57:58
在安装和实施Flutter团队提供的应用内购买插件后,我遇到了一个问题。到目前为止,我做了什么:
- 在Play商店中添加了2个可见且有效的产品。
- 提交了用于 Alpha 测试的构建版本,因为这是应用内购买工作所必需的。
- 在应用启动时添加
InAppPurchaseConnection.enablePendingPurchases();
- 创建了一系列对应用商店的请求,其中最后一个失败,日志很糟糕,我无法解决
bool available = await _iap.isAvailable();
if (!available) {
print('=========> The store cannot be reached or accessed.');
} else {
Set<String> _kIds = {'farm', 'forest'};
ProductDetailsResponse productsResponse = await _iap.queryProductDetails(_kIds);
List<ProductDetails> products = productsResponse.productDetails;
}
}
- 目前,每次崩溃,并使用以下日志:
queryProductDetails
E/AndroidRuntime( 9053): java.lang.NoSuchMethodError: No virtual method getIntroductoryPriceCycles()Ljava/lang/String; in class Lcom/android/billingclient/api/SkuDetails; or its super classes (declaration of 'com.android.billingclient.api.SkuDetails' appears in /data/app/com.my.fancy.app-6ImcBn8ELPgiO8hTXXp_3Q==/base.apk)
E/AndroidRuntime( 9053): at io.flutter.plugins.inapppurchase.Translator.fromSkuDetail(Translator.java:27)
E/AndroidRuntime( 9053): at io.flutter.plugins.inapppurchase.Translator.fromSkuDetailsList(Translator.java:49)
E/AndroidRuntime( 9053): at io.flutter.plugins.inapppurchase.MethodCallHandlerImpl$1.onSkuDetailsResponse(MethodCallHandlerImpl.java:185)
E/AndroidRuntime( 9053): at com.android.billingclient.api.zzj.run(com.android.billingclient:billing@@3.0.0:8)
E/AndroidRuntime( 9053): at android.os.Handler.handleCallback(Handler.java:873)
E/AndroidRuntime( 9053): at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime( 9053): at android.os.Looper.loop(Looper.java:193)
E/AndroidRuntime( 9053): at android.app.ActivityThread.main(ActivityThread.java:6746)
E/AndroidRuntime( 9053): at java.lang.reflect.Method.invoke(Native Method)
E/AndroidRuntime( 9053): at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
E/AndroidRuntime( 9053): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
我尝试过在多个示例项目上运行它,但它失败了。尝试使用Kotlin和Java项目,只是为了看看其中一个是否有错误,但没有运气。
编辑(修复了问题):问题是由导致此问题的 build.gradle 文件中链接的计费客户端导致的。一旦我从gradle文件中删除它,一切都开始按预期工作。