24

我通过 Gradle 在我的 Android 应用程序中集成了 FB SDK,用于登录和跟踪事件。登录工作正常,但是一旦我尝试记录应用程序事件,logcat 就会每 15 秒向我显示一次异常:

D/com.facebook.appevents.AppEventsLogger: Got unexpected exception: java.lang.ClassNotFoundException: com.facebook.a.b

它在 PersistedEvents 的 readAndClearStore() 方法中被抛出

这是我记录事件的代码:

AppEventsLogger logger = AppEventsLogger.newLogger(this);
    Bundle parameters = new Bundle();
    parameters.putString(AppEventsConstants.EVENT_PARAM_CURRENCY, "EUR");
    parameters.putString(AppEventsConstants.EVENT_PARAM_CONTENT_TYPE, "product");
    parameters.putString(AppEventsConstants.EVENT_PARAM_CONTENT_ID, id);

    logger.logEvent(AppEventsConstants.EVENT_NAME_VIEWED_CONTENT,
            1.99,
            parameters);

我的意思是com.facebook.a.b对我来说看起来像是一个proguard问题。但是在 FB SDK 文档中,他们明确指出您不需要输入任何 proguard 规则即可使其工作。当我不缩小我的应用程序以及从 github 下载 sdk 并将其作为模块包含时,也会显示此错误。

4

2 回答 2

1

几天前,我在Facebook SDK(v4.11.0)中的记录器遇到了类似的问题:

D/com.facebook.a.a(PID): Got unexpected exception: java.io.WriteAbortedException: Read an exception; java.io.NotSerializableException: org.json.JSONObject

在他们的文档中,他们说了以下内容:

您无需执行任何其他步骤即可将 ProGuard 用于 Facebook Android SDK。有关 Proguard 的说明,请参阅 Android 工具项目站点,运行 ProGuard。

在查看了导致我在发布环境中没有记录任何事件的原因之后,我将以下规则添加到我的 proguard 文件中,然后神奇地开始正常工作:

-keep class com.facebook.** { *; }

我们已经向 facebook 开发者团队开张票,以获得更多相关信息。https://developers.facebook.com/bugs/250752828645777/

于 2016-05-09T01:08:31.643 回答
0

在 gradle 中使用而不是 sdk:4.11.0:

compile('com.facebook.android:facebook-android-sdk:3.23.0') {
    exclude module: 'bolts-android'
}

我也无法使用 fb sdk: 4.11.0 登录,因为这个版本的 fb sdk 确实提供了 Facebook 类的异常。使用更高版本的 fb sdk,新类正在取代旧类。

即使在新版本 23 中,ActionBaractivity 也在贬低,因此需要使用 AppCompatActivity。

于 2016-11-22T12:50:02.223 回答