android - 在 android 中将 quickblox 与 Proguard 集成

标签 android nullpointerexception proguard quickblox

我在我的 Android 应用程序中使用 QuickBlox 进行聊天。

[2014-09-22 12:32:48 - Dex Loader] Unable to execute dex: method ID not in [0, 0xffff]: 65536 [2014-09-22 12:32:48 - xxxx] Conversion to Dalvik format failed: Unable to execute dex: method ID not in [0, 0xffff]: 65536

然后有人建议我在应用程序中实现 Proguard,以删除应用程序不需要的所有不必要的方法。但是,当我在我的 Android 设备中安装带有集成混淆器的签名 apk 时,我遇到了这个问题,并且应用程序在登录 QuickBlox 时因空指针异常而崩溃。

09-22 12:43:50.875: E/AndroidRuntime(10513): FATAL EXCEPTION: main
09-22 12:43:50.875: E/AndroidRuntime(10513): Process: com.xxxx, PID: 10513
09-22 12:43:50.875: E/AndroidRuntime(10513): java.lang.NullPointerException
09-22 12:43:50.875: E/AndroidRuntime(10513):    at com.quickblox.b.a.a.a.a(Unknown Source)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at com.quickblox.b.a.a.f.b(Unknown Source)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at com.quickblox.b.a.a.f.a(Unknown Source)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at com.quickblox.b.a.a.b.a(Unknown Source)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at com.quickblox.b.a.a.e.a(Unknown Source)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at com.quickblox.b.a.a.c.a(Unknown Source)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at com.quickblox.b.a.h.d.handleMessage(Unknown Source)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at android.os.Handler.dispatchMessage(Handler.java:102)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at android.os.Looper.loop(Looper.java:136)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at android.app.ActivityThread.main(ActivityThread.java:5001)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at java.lang.reflect.Method.invokeNative(Native Method)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at java.lang.reflect.Method.invoke(Method.java:515)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
09-22 12:43:50.875: E/AndroidRuntime(10513):    at dalvik.system.NativeStart.main(Native Method)

我只是一个集成Proguard的新手,但是我发现只有在我编写QuickBlox的日志记录模块的代码时才会出现这种情况。

最佳答案

我解决了这个问题。实际上这是我这边的错误。我忘了从 Android 端在 QuickBlox 中创建 session 。:

QBSettings.getInstance().fastConfigInit(APP_ID, AUTH_KEY, AUTH_SECRET);
QBAuth.createSession(new QBEntityCallbackImpl<QBSession>() {

        @Override
        public void onSuccess(QBSession session, Bundle params) {
            super.onSuccess(session, params);

            Log.i(com.hyperchat.Consts.TAG, "session created, token = "
                    + session.getToken());

        }

        @Override
        public void onError(List<String> errors) {

        }
    });

执行此操作后,错误消失,应用程序运行顺利!!

关于android - 在 android 中将 quickblox 与 Proguard 集成,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25969231/

相关文章:

Android 许可错误 561 - 此应用程序未获得许可。请从 Android Market 购买

android - 使用 ActionBarSherlock 的 setShareIntent 上的 NullPointerException

java - 如何修复 Findbugs 问题 "Null value is guaranteed to be dereferenced"NP_GUARANTEED_DEREF

android - 使用 Picasso 和 minifyEnabled 时应用程序崩溃 true

android - 在 fragment 中获取 Assets

android - 在Android Studio中安装Roboguice

android - 从 Android 4.4 Kitkat 设置闹钟

java - 使用 Java InputStream 复制文件时如何创建不存在的文件夹/子目录?

android - Flutter:将 Proguard 与 Gradle 7.0.4 结合使用

android - Proguard 导致 Android 上的 SSL keystore 出现问题