编辑4/15:在IabHelper中捕获空指针似乎已停止了此问题。我不再看到引发异常的情况,我将接受它作为答案。

编辑4/04:更深层次的潜水。有尝试catch块可处理queryPurchases方法的RemoteExceptions和JSONExceptions,但没有NullPointerException处理。我要尝试的是包括NullPointer异常处理,因此,当尝试查询SkuDetails时,IabHelper如下所示:

    catch (NullPointerException e) {
        throw new IabException(IABHELPER_UNKNOWN_ERROR, "NullPointer while refreshing inventory.", e);
    }

我只是对此提交了一个错误:

https://code.google.com/p/marketbilling/issues/detail?id=114

编辑3/25:很好,仍然收到此崩溃...现在,在尝试从IabHelper摘录的以下摘录的第3行获取上下文时,它发生了:
int queryPurchases(Inventory inv, String itemType) throws JSONException, RemoteException {
    logDebug("Querying owned items, item type: " + itemType);
    logDebug("Package name: " + mContext.getPackageName());

这令人沮丧,因为在 list 中,我始终将应用程序的完整路径名用作“名称”。

示例“com.myappname.blah.ClassName”

我也尝试过将MyClass.this,getApplicationContext()传递给mHelper。但是,它们在野外的设备中随机产生相同的NullPointer结果。我还在 list 中尝试了name =“。MyClass”。这是当前的样子:
mHelper = new IabHelper(MyClass.this, myKey);

编辑 3/18/13:即使在3/17上部署了新的IabHelper版本,我仍然收到异常。

我在这里开始看到一种模式,当执行mContext.getPackageName()时尝试获取上下文时,所有崩溃都在崩溃。我很好奇为什么这可以在我所有的测试设备上使用,并且我无法重现此崩溃,而似乎只在少数设备上如此。

这是新的崩溃:
java.lang.NullPointerException
    at com.myapp.util.IabHelper.queryPurchases(SourceFile:836)
    at com.myapp.util.IabHelper.queryInventory(SourceFile:558)
    at com.myapp.util.IabHelper.queryInventory(SourceFile:522)
    at com.myapp.util.IabHelper$2.run(SourceFile:617)
    at java.lang.Thread.run(Thread.java:1019)

由IabHelper引起...
line 836: logDebug("Package name: " + mContext.getPackageName());

编辑 13/3/17:我看到过去几个月发布了许多错误修复,我将在此处尝试最新的代码,看看是否可以解决问题:

https://code.google.com/p/marketbilling/source/browse/v3/src/com/example/android/trivialdrivesample/util

在我的一个应用程序中,我正在使用计费API及其随附的样板代码。

我正在使用截至2013年3月16日通过SDK管理器提供的最新版本的计费API。

在我的 Activity 中,我使用以下查询库存:
final List<String> skuList = new ArrayList<String>();
skuList.add("sku1");
skuList.add("sku2");
skuList.add("sku3");
if (skuList != null) {
    if (skuList.size() > 0) {
        try {
            mHelper.queryInventoryAsync(true, skuList, mGotInventoryListener);
        } catch (Exception e) {
            ACRA.getErrorReporter().handleException(e);
        }
    }
}

我从IabHelper类的以下设备中狂野地收到了多个NullPointerException报告。我无法重现该问题,也无法找到有关这些崩溃的任何信息,这就是我发布此问题的原因。

我在计费API的“面向开发人员”部分中(包括onQueryInventoryFinished中)对空值和try/catch块进行了无数其他检查,因此我知道不会从“我的代码”中抛出此异常(因为我没有捕获崩溃从我的应用程序的任何类),而是从IabHelper本身抛出。除了此建议的修复程序之外,我没有修改IabHelper:https://stackoverflow.com/a/14737699

崩溃#1 Galaxy Nexus
java.lang.NullPointerException
    at com.myapp.util.IabHelper.querySkuDetails(SourceFile:802)
    at com.myapp.util.IabHelper.queryInventory(SourceFile:471)
    at com.myapp.util.IabHelper$2.run(SourceFile:521)
    at java.lang.Thread.run(Thread.java:856)

由IabHelper引起...
line 802: Bundle skuDetails = mService.getSkuDetails(3, mContext.getPackageName(), ITEM_TYPE_INAPP, querySkus);

崩溃#2三星GT-S5570L
java.lang.NullPointerException
    at com.myapp.util.IabHelper.queryPurchases(SourceFile:735)
    at com.myapp.util.IabHelper.queryInventory(SourceFile:465)
    at com.myapp.util.IabHelper$2.run(SourceFile:521)
    at java.lang.Thread.run(Thread.java:1019)

由IabHelper引起...
line 735: Bundle ownedItems = mService.getPurchases(3, mContext.getPackageName(), ITEM_TYPE_INAPP, continueToken);

最佳答案

编辑4/15:在IabHelper中捕获空指针似乎已停止了此问题。我不再看到引发异常的情况,我将接受它作为答案。

编辑4/04:更深层次的潜水。有尝试catch块可处理queryPurchases方法的RemoteExceptions和JSONExceptions,但没有NullPointerException处理。我要尝试的是包括NullPointer异常处理,因此,当尝试查询SkuDetails时,IabHelper如下所示:

    catch (NullPointerException e) {
        throw new IabException(IABHELPER_UNKNOWN_ERROR, "NullPointer while refreshing inventory.", e);
    }

我只是对此提交了一个错误:

https://code.google.com/p/marketbilling/issues/detail?id=114

改变
        if (querySkuDetails) {
            r = querySkuDetails(ITEM_TYPE_INAPP, inv, moreItemSkus);
            if (r != BILLING_RESPONSE_RESULT_OK) {
                throw new IabException(r, "Error refreshing inventory (querying prices of items).");
            }
        }


        if (querySkuDetails) {
            try {
                r = querySkuDetails(ITEM_TYPE_INAPP, inv, moreItemSkus);
                if (r != BILLING_RESPONSE_RESULT_OK) {
                    throw new IabException(r, "Error refreshing inventory (querying prices of items).");
                }
            } catch (NullPointerException e) {
                throw new IabException(IABHELPER_UNKNOWN_ERROR, "NPE while refreshing inventory.", e);
            }
        }

改变
            if (querySkuDetails) {
                r = querySkuDetails(ITEM_TYPE_SUBS, inv, moreSubsSkus);
                if (r != BILLING_RESPONSE_RESULT_OK) {
                    throw new IabException(r, "Error refreshing inventory (querying prices of subscriptions).");
                }
            }


            if (querySkuDetails) {
                try {
                    r = querySkuDetails(ITEM_TYPE_SUBS, inv, moreSubsSkus);
                    if (r != BILLING_RESPONSE_RESULT_OK) {
                        throw new IabException(r, "Error refreshing inventory (querying prices of subscriptions).");
                    }
                } catch (NullPointerException e) {
                    throw new IabException(IABHELPER_UNKNOWN_ERROR, "NPE while refreshing inventory.", e);
                }
            }

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

10-10 04:54