【发布时间】:2012-11-12 08:22:45
【问题描述】:
警告:我删除了很多“旧文本”以保持问题更清晰。如果需要,只需检查历史记录。
我正在使用proguard 来缩小和混淆使用facebook sdk 3.0 的应用程序(我正在使用sdk-version-3.0.2.b tag)。我没有使用 JAR 文件。相反,我按照documentation 的教导将 sdk 导入到我的工作区中。
在执行的某个时刻,应用会加载一个PlacePickerFragment,让用户选择他所在的位置。为了编写代码,我完全遵循Scrumptious tutorial。 当我在不使用proguard 的情况下生成调试 apk 时,一切都按预期工作。 但是当我使用 proguard 生成签名 apk 时,当 PlacePickerFragment 加载具有以下跟踪的附近地点时,它会崩溃: p>
E/AndroidRuntime(27472): FATAL EXCEPTION: main
E/AndroidRuntime(27472): com.facebook.FacebookGraphObjectException: can't infer generic type of: interface com.facebook.model.GraphObjectList
E/AndroidRuntime(27472): at com.facebook.model.GraphObject$Factory.coerceValueToExpectedType(Unknown Source)
E/AndroidRuntime(27472): at com.facebook.model.GraphObject$Factory$GraphObjectProxy.proxyGraphObjectGettersAndSetters(Unknown Source)
E/AndroidRuntime(27472): at com.facebook.model.GraphObject$Factory$GraphObjectProxy.invoke(Unknown Source)
E/AndroidRuntime(27472): at com.facebook.widget.$Proxy2.getData(Native Method)
E/AndroidRuntime(27472): at com.facebook.widget.GraphObjectPagingLoader.addResults(Unknown Source)
E/AndroidRuntime(27472): at com.facebook.widget.GraphObjectPagingLoader.requestCompleted(Unknown Source)
E/AndroidRuntime(27472): at com.facebook.widget.GraphObjectPagingLoader.access$1(Unknown Source)
E/AndroidRuntime(27472): at com.facebook.widget.GraphObjectPagingLoader$2.onCompleted(Unknown Source)
E/AndroidRuntime(27472): at com.facebook.Request$4.run(Unknown Source)
E/AndroidRuntime(27472): at android.os.Handler.handleCallback(Handler.java:587)
E/AndroidRuntime(27472): at android.os.Handler.dispatchMessage(Handler.java:92)
E/AndroidRuntime(27472): at android.os.Looper.loop(Looper.java:130)
E/AndroidRuntime(27472): at android.app.ActivityThread.main(ActivityThread.java:3687)
E/AndroidRuntime(27472): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(27472): at java.lang.reflect.Method.invoke(Method.java:507)
E/AndroidRuntime(27472): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
E/AndroidRuntime(27472): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
E/AndroidRuntime(27472): at dalvik.system.NativeStart.main(Native Method)
为了避免这个错误,我保持所有 facebook 类不变,但没有工作。我当前的proguard-project.txt 文件:
-keep class com.facebook.** {
*;
}
我当前的projet.properties 文件(摘录):
proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt
如您所见,我的proguard 配置是this file 的“特化”。
如果我将-dontobfuscate 放入proguard-project.txt 文件中,它将起作用。 但我不明白的是keep class com.facebook.** 应该已经防止与facebook 相关的类被混淆。这表明问题与 facebook 类没有直接关系。
抛出com.facebook.FacebookGraphObjectException的excerpt of code是:
static <U> U coerceValueToExpectedType(Object value, Class<U> expectedType,
ParameterizedType expectedTypeAsParameterizedType) {
// [...]
} else if (Iterable.class.equals(expectedType) || Collection.class.equals(expectedType)
|| List.class.equals(expectedType) || GraphObjectList.class.equals(expectedType)) {
if (expectedTypeAsParameterizedType == null) {
throw new FacebookGraphObjectException("can't infer generic type of: " + expectedType.toString());
}
// [...]
}
显然,expectedTypeAsParameterizedType 在发布版本中是 null。但是在两个版本(调试和发布)中,expectedType 是一个com.facebook.model.GraphObjectList 接口。不幸的是,我对 Java 反射概念几乎一无所知。
我该如何解决这个问题?
【问题讨论】:
标签: android facebook proguard facebook-android-sdk