android - 在应用计费 v3 NullPointerException

标签 android nullpointerexception in-app-billing

为了在适用于 Android 的应用计费 v3 中进行测试,我实现了一个对话框,其中添加了一个单选项目适配器。我添加了测试 Skus,“android.test.purchased”、“android.test.canceled”、“android.test.refunded”、“android.test.item_unavailable”。

当我使用对话框启动购买流程时,一切都很好,我可以购买该商品,而且该商品已确定购买。但是,当我的应用程序随后尝试刷新 UI 时,我得到了一个 nullpointerexception。我知道刷新有效。

这是我的日志:

12-16 01:06:06.706: I/Running inventory query with(20846): android.test.purchased
12-16 01:06:06.706: I/Running details query with(20846): SkuDetails:{"title":"Sample Title","price":"£0.61","type":"inapp","description":"Sample description for product: android.test.purchased.","productId":"android.test.purchased"}
12-16 01:06:06.706: I/Running details query with(20846): SkuDetails:{"title":"Sample Title","price":"£0.61","type":"inapp","description":"Sample description for product: android.test.purchased.","productId":"android.test.purchased"}
12-16 01:06:06.706: I/Running inventory query with(20846): android.test.canceled
12-16 01:06:06.706: I/Running details query with(20846): null
12-16 01:06:06.706: I/Running details query with(20846): null
12-16 01:06:06.706: D/AndroidRuntime(20846): Shutting down VM
12-16 01:06:06.706: W/dalvikvm(20846): threadid=1: thread exiting with uncaught exception (group=0x40d12930)
12-16 01:06:06.706: E/AndroidRuntime(20846): FATAL EXCEPTION: main
12-16 01:06:06.706: E/AndroidRuntime(20846): java.lang.NullPointerException
12-16 01:06:06.706: E/AndroidRuntime(20846): at com.example.test.MainActivity$1.onQueryInventoryFinished(MainActivity.java:201)
12-16 01:06:06.706: E/AndroidRuntime(20846): at com.example.test.util.IabHelper$2$1.run(IabHelper.java:536)
12-16 01:06:06.706: E/AndroidRuntime(20846): at android.os.Handler.handleCallback(Handler.java:725)
12-16 01:06:06.706: E/AndroidRuntime(20846): at android.os.Handler.dispatchMessage(Handler.java:92)
12-16 01:06:06.706: E/AndroidRuntime(20846): at android.os.Looper.loop(Looper.java:137)
12-16 01:06:06.706: E/AndroidRuntime(20846): at android.app.ActivityThread.main(ActivityThread.java:5039)
12-16 01:06:06.706: E/AndroidRuntime(20846): at java.lang.reflect.Method.invokeNative(Native Method)
12-16 01:06:06.706: E/AndroidRuntime(20846): at java.lang.reflect.Method.invoke(Method.java:511)
12-16 01:06:06.706: E/AndroidRuntime(20846): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
12-16 01:06:06.706: E/AndroidRuntime(20846): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
12-16 01:06:06.706: E/AndroidRuntime(20846): at dalvik.system.NativeStart.main(Native Method)

for (String s : allSkus) {
Log.i("Running inventory query with", "" + s);
SkuDetails c = inv.getSkuDetails(s);
Log.i("Running details query with", "" + c);
if (inv.hasPurchase(s)) {
    purchaseArray.add(c.getTitle());
} else {
    **LINE 201** objects.add(c.getPrice() + "  T:" + c.getSku());
}

allSkus 是一个 ArrayList,它包含上面的 4 个 skus。

空指针是 SkuDetails c = inv.getSkuDetails(s);

在 UI 刷新时返回 null。但问题是它似乎适用于第一个 sku (android.test.purchased) 但对第二个 sku (android.test.canceled) 为 null 并且它也只有在购买另一个项目后运行时才为 null (退款或购买)。但是,如果我随后再次打开它,就可以了,并且不会抛出 nullpointerexception。

如果我在添加到 ArrayList 对象之前添加 null 检查,则不会添加任何项目,因为在 inv.getSkuDetails(s) 上购买的项目返回 null 之后或之前的每个项目

最佳答案

这让我感到难过,接受的答案没有包含相关的细节。

你需要做的是在调用 startSetup 后传递一个列表,其中包含你要查询的 SKU(是否已购买)。因此它看起来类似于下面的代码,而不是(不充分的)样板 TrivialDrive 示例中提供的代码。

mHelper.queryInventoryAsync(true, skuList, mGotInventoryListener);

此外,看起来还有一些幻影方法(在评论中仍未清理,这也是不准确的)...此处有关该错误的更多详细信息:

http://code.google.com/p/marketbilling/issues/detail?id=98

关于android - 在应用计费 v3 NullPointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13897809/

相关文章:

android - Google Play IAB 突然不适用于我的手机

android - 如何在 Kotlin 中正确使用 setOnLongClickListener()

java - android中可以离线工作的语音识别

android - 检查 SharedPrefs 是否等于 Null 时出现空指针异常

android - toLowerCase 上的 NullPointer 但我不在任何地方使用该方法

java - Android 应用内支付公钥异常

android - 是否可以在Android中编译LaTex?

java - In-App Billing Android 和 bug

java - 部分填充的数组和 NullPointerException

android - 在 Google Play 的 Billing API v3 中解决消耗品的 API-purchase-logic-flaws(与使用 API v3 消耗品的每个人相关)