Android在应用程序结算测试购买崩溃Play商店

我目前正在开发一个应用程序在应用程序结算。 一切正常。 并且我已经在Beta版频道中发布了该应用,并通过测试用户使用真实内容对其进行了测试,并且它很有用。

然而,在调试时,我使用android.test.purchased项目,当我按下buy按钮时,我的Play商店崩溃。

在这里输入图像描述

我收到以下错误信息:

E/AndroidRuntime: FATAL EXCEPTION: main 
                        Process: com.android.vending, PID: 25463
                                                   java.lang.NullPointerException: Attempt to read from field 'com.google.android.finsky.protos.Acquisition$AutoDismissTemplate com.google.android.finsky.protos.Acquisition$PostAcquisitionPrompt.autoDismissTemplate' on a null object reference
                                                       at com.google.android.finsky.billing.SuccessStep.getLayoutResId(SuccessStep.java:75)
                                                       at com.google.android.finsky.billing.lightpurchase.PurchaseFragment.onStateChange(PurchaseFragment.java:31066)
                                                       at com.google.android.finsky.fragments.SidecarFragment.notifyListener(SidecarFragment.java:255)
                                                       at com.google.android.finsky.fragments.SidecarFragment.setState(SidecarFragment.java:250)
                                                       at com.google.android.finsky.billing.lightpurchase.CheckoutPurchaseSidecar.confirmAuthChoiceSelected(CheckoutPurchaseSidecar.java:631)
                                                       at com.google.android.finsky.billing.lightpurchase.PurchaseFragment.onStateChange(PurchaseFragment.java:32156)
                                                       at com.google.android.finsky.fragments.SidecarFragment.notifyListener(SidecarFragment.java:255)
                                                       at com.google.android.finsky.fragments.SidecarFragment.setState(SidecarFragment.java:250)
                                                       at com.google.android.finsky.billing.lightpurchase.CheckoutPurchaseSidecar.access$1900$2f730cd3(CheckoutPurchaseSidecar.java:72)
                                                       at com.google.android.finsky.billing.lightpurchase.CheckoutPurchaseSidecar$1.run(CheckoutPurchaseSidecar.java:1009)
                                                       at android.os.Handler.handleCallback(Handler.java:739)
                                                       at android.os.Handler.dispatchMessage(Handler.java:95)
                                                       at android.os.Looper.loop(Looper.java:148)
                                                       at android.app.ActivityThread.main(ActivityThread.java:5417)
                                                       at java.lang.reflect.Method.invoke(Native Method)
                                                       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
                                                       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
11-23 02:22:43.202 590-739/? W/ActivityManager:   Force finishing activity com.android.vending/com.google.android.finsky.billing.lightpurchase.IabV3Activity


Purchase finished: IabResult: Null data in IAB result (response: -1002:Bad response received), purchase: null
Error purchasing: IabResult: Null data in IAB result (response: -1002:Bad response received)

有时会在购买之后继续购买,其他时候,我的应用会崩溃。

我在几款设备上测试了它(Nexus 7与Android 6.0,注意5与Android 5.1.1,Galaxy S3与Android 4.3,LG G3与Android 4.4),都具有相同的行为。

什么让我发疯是真正的应用程序项目工作完美无瑕。 这让我觉得这意味着我的代码很好。 但是在测试项目发生这种情况时,让我担心在发布时,真实用户可能会重复真实项目。

感谢您的帮助,让我知道如果我做错了什么导致玩商店崩溃,或者这可能发生?

请注意,我对Android开发相当陌生。

谢谢。

这是我在应用程序结算中的代码:

 ///... part of onCreate:

 mHelper = new IabHelper(this, base64EncodedPublicKey);

        mHelper.startSetup(new
                                   IabHelper.OnIabSetupFinishedListener() {
                                       public void onIabSetupFinished(IabResult result) {
                                           if (!result.isSuccess()) {
                                               Log.d(TAG, "In-app Billing setup failed: " +
                                                       result);
                                           } else {
                                               // Hooray, IAB is fully set up. Now, let's get an inventory of
                                               // stuff we own.
                                               Log.d(TAG, "Setup successful. Querying inventory.");
                                                mHelper.queryInventoryAsync(mGotInventoryListener);                                           }
                                       }
                                   });

/////////////////

public void startPurchase(String ITEM_SKU) { // Start the purchase process here

    String purchaseToken = "inapp:" + getPackageName() + ":"+ ITEM_SKU;

    Log.d(TAG, "Purchase started for : " + ITEM_SKU);

    mHelper.launchPurchaseFlow(this, ITEM_SKU, 10002,
                mPurchaseFinishedListener, purchaseToken);
}


// Callback for when a purchase is finished
IabHelper.OnIabPurchaseFinishedListener mPurchaseFinishedListener = new IabHelper.OnIabPurchaseFinishedListener() {
    public void onIabPurchaseFinished(IabResult result, Purchase purchase) {
        Log.d(TAG, "Purchase finished: " + result + ", purchase: "
                + purchase);
        if (result.isFailure()) {
            Log.d(TAG,"Error purchasing: " + result);
            if (result.getResponse()==7){
                if(myInventory.hasPurchase(ITEM_SKU))
                {
                    Log.d(TAG,"Ooops, Item already purchased, consume it");
                    mHelper.consumeAsync(myInventory.getPurchase(ITEM_SKU),mConsumeFinishedListener2);
                }
            }
            return;
        }

        Log.d(TAG, "Purchase successful.");

        if (purchase.getSku().equals(ITEM_SKU)) {
            mHelper.consumeAsync(purchase, mConsumeFinishedListener);

        }
    }
};

IabHelper.QueryInventoryFinishedListener mGotInventoryListener = new IabHelper.QueryInventoryFinishedListener() {
    public void onQueryInventoryFinished(IabResult result,
                                         Inventory inventory) {
        Log.d(TAG, "Query inventory finished.");

        if (result.isFailure()) {
            Log.d(TAG,"Failed to query inventory: " + result);
            return;
        }

        Log.d(TAG, "Query inventory was successful.");

        myInventory = inventory;
        //Process inventory


    }
};

IabHelper.OnConsumeFinishedListener mConsumeFinishedListener =
        new IabHelper.OnConsumeFinishedListener() {
            public void onConsumeFinished(Purchase purchase,
                                          IabResult result) {

                if (result.isSuccess()) {
                    Log.d(TAG,"consume successful for " + purchase.getSku() + " & " + result.getMessage());
                    updateCoinsAndScore(coinsToAdd, 0);
                    Toast.makeText(getApplication(), "تم إضافة عدد " + coinsToAdd + " عملات إلى رصيدك", Toast.LENGTH_LONG).show();
                    //reset values
                    coinsToAdd=0;
                    ITEM_SKU="";
                } else {
                    Log.d(TAG, "Consume failed " + result.getMessage());                    }
            }
        };

IabHelper.OnConsumeFinishedListener mConsumeFinishedListener2 =
        new IabHelper.OnConsumeFinishedListener() {
            public void onConsumeFinished(Purchase purchase,
                                          IabResult result) {

                if (result.isSuccess()) {
                    Log.d(TAG,"consumed, starting purchase again");
                    Log.d(TAG,"consume successful for " + purchase.getSku() + " & " + result.getMessage());

                    startPurchase(ITEM_SKU);

                } else {
                    Log.d(TAG,"Consume failed " + result.getMessage());                    }
            }
        };

问题出现在Google Play v6.0.0中,现在它已经在v6.0.5中进行了修复(在三星和Nexus设备上均已确认)。

如果您没有自动获取Google Play更新,则可以从ApkMirror.com手动下载。

链接地址: http://www.djcxy.com/p/30475.html

上一篇: Android in App billing test purchase crashes Play store

下一篇: Why won't HttpPlatformHandler create log files?