簡體   English   中英

Iabhelper在某些設備上的Firebase測試實驗室中崩潰

[英]Iabhelper crashes in Firebase Test lab on some devices

在Firebase測試實驗室中測試我的應用程序時,我在2個設備上收到以下錯誤,與其他2個設備配合得很好:

java.lang.RuntimeException: Unable to start activity ComponentInfo{MyActivity}: java.lang.NullPointerException: Attempt to invoke interface method 'boolean java.util.List.isEmpty()' on a null object reference
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2345)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2407)
at android.app.ActivityThread.access$800(ActivityThread.java:149)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1324)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:211)
at android.app.ActivityThread.main(ActivityThread.java:5321)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1016)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:811)


Caused by: java.lang.NullPointerException: Attempt to invoke interface method 'boolean java.util.List.isEmpty()' on a null object reference
at util.IabHelper.startSetup(IabHelper.java:267)
at MenuActivity.onCreate(MenuActivity.java:68)
at CameraActivity.onCreate(CameraActivity.java:19)
at android.app.Activity.performCreate(Activity.java:5933)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)
... 10 more

因此,似乎是來自IabHelper初始化的問題,這是我設置它的代碼:

String base64EncodedPublicKey = "MyKey";

    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 {
                                   Log.d(TAG, "In-app Billing is set up OK");
                               }
                           }
                       });

它可以完美地在我的測試電話和2個Alpha測試人員的電話上正常工作。 有人對此有任何線索嗎?

因此,這是一個已修復的錯誤,似乎我正在使用舊版本的IabHelper。 如果有人在尋找它,請在IabHelper.java的第267行中更改以下內容:

更換:

if (!mContext.getPackageManager().queryIntentServices(serviceIntent, 0).isEmpty()) {

有:

List<ResolveInfo> resolveInfoList = mContext.getPackageManager().queryIntentServices(serviceIntent, 0);
if (resolveInfoList != null && !resolveInfoList.isEmpty()) {

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM