Сбой биллинга Android в приложении при получении цены товара - PullRequest
0 голосов
/ 26 апреля 2018

Я пытаюсь реализовать Android-биллинг внутри приложения.

Что я сделал до сих пор:

  1. Добавлен файл aidl.
  2. Добавлены файлы util-helper.
  3. Создано приложение на игровой консоли
  4. Загрузил signed APK и добавил продукт в игровую консоль.
  5. Добавлен некоторый код в файл Shop.java. Это работает нормально, пока я не попытаюсь получить цену товара (см. Код между: //THIS IS WHERE THE APP CRASHES ниже).

Вот код, который я использую внутри onCreate() в Shop.java

onCreate() {

    //In App Billing
    key = "XXX";
    mHelper = new IabHelper(this, key);
    mHelper.startSetup(new IabHelper.OnIabSetupFinishedListener() {
        public void onIabSetupFinished(IabResult result) {

            if (!result.isSuccess()) {
                Log.d(TAG, "In-app Billing setup failed: " + result);
                return;
            }

            if (mHelper == null) return;


            Log.d(TAG, "Setup successful. Querying inventory.");
            try {
                mHelper.queryInventoryAsync(mGotInventoryListener);
            } catch (IabHelper.IabAsyncInProgressException e) {

            }

        }
    });
}

А потом mGotInventoryListener:

IabHelper.QueryInventoryFinishedListener mGotInventoryListener = new IabHelper.QueryInventoryFinishedListener() {
    public void onQueryInventoryFinished(IabResult result, Inventory inventory) {

        // Have we been disposed of in the meantime? If so, quit.
        if (mHelper == null) return;

        if (result.isFailure()) {
            // handle error
            return;
        }

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

        // Do we have the premium upgrade?
        Purchase premiumPurchase = inventory.getPurchase(ITEM_SKU);
        boolean mIsPremium = (premiumPurchase != null);
        Log.d(TAG, "User is " + (mIsPremium ? "PREMIUM" : "NOT PREMIUM"));



        //THIS IS WHERE THE APP CRASHES
        String price = inventory.getSkuDetails(ITEM_SKU).getPrice();
        //THIS IS WHERE THE APP CRASHES


        updateUI();
    }
};

СООБЩЕНИЕ ОБ ОШИБКЕ:

E/AndroidRuntime: FATAL EXCEPTION: main
                                                                           Process: example.com.app, PID: 4270
                                                                           java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String example.com.app.util.SkuDetails.getPrice()' on a null object reference
                                                                               at example.com.app.Shop$2.onQueryInventoryFinished(Shop.java:234)
                                                                               at example.com.app.util.IabHelper$2$1.run(IabHelper.java:711)
                                                                               at android.os.Handler.handleCallback(Handler.java:751)
                                                                               at android.os.Handler.dispatchMessage(Handler.java:95)
                                                                               at android.os.Looper.loop(Looper.java:154)
                                                                               at android.app.ActivityThread.main(ActivityThread.java:6692)
                                                                               at java.lang.reflect.Method.invoke(Native Method)
                                                                               at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1468)
                                                                               at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1358)

1 Ответ

0 голосов
/ 26 апреля 2018
inventory.getSkuDetails(ITEM_SKU);

возвращает объект SkuDetails.Но этот объект может быть нулевым

SkuDetails details = inventory.getSkuDetails(ITEM_SKU);
if (details == null) {
   return;
};
String price = details.getPrice();
...