最近,忙完公司的一个版本。打包签名过后,发现App不能够正常运行使用,在网上查找了许多方法无果。
先贴上Log:
03-02 18:54:11.460: E/TestinAgent(3754): ****************************************
03-02 18:54:12.285: E/AndroidRuntime(3754): FATAL EXCEPTION: main
03-02 18:54:12.285: E/AndroidRuntime(3754): java.lang.NoSuchFieldError: PUBLIC_ONLY
03-02 18:54:12.285: E/AndroidRuntime(3754): at java.lang.Class.getDeclaredAnnotation(Native Method)
03-02 18:54:12.285: E/AndroidRuntime(3754): at java.lang.Class.getAnnotation(Class.java:243)
03-02 18:54:12.285: E/AndroidRuntime(3754): at org.codehaus.jackson.map.introspect.VisibilityChecker$Std.<clinit>(VisibilityChecker.java:178)
03-02 18:54:12.285: E/AndroidRuntime(3754): at org.codehaus.jackson.map.ObjectMapper.<clinit>(ObjectMapper.java:196)
03-02 18:54:12.285: E/AndroidRuntime(3754): at com.app.util.JacksonParser.readValue(JacksonParser.java:22)
03-02 18:54:12.285: E/AndroidRuntime(3754): at com.app.util.ArticleCollection.onResponse(ArticleCollection.java:60)
03-02 18:54:12.285: E/AndroidRuntime(3754): at com.app.util.ArticleCollection.onResponse(ArticleCollection.java:1)
03-02 18:54:12.285: E/AndroidRuntime(3754): at com.android.volley.toolbox.JsonRequest.deliverResponse(JsonRequest.java:65)
03-02 18:54:12.285: E/AndroidRuntime(3754): at com.android.volley.ExecutorDelivery$ResponseDeliveryRunnable.run(ExecutorDelivery.java:99)
03-02 18:54:12.285: E/AndroidRuntime(3754): at android.os.Handler.handleCallback(Handler.java:730)
03-02 18:54:12.285: E/AndroidRuntime(3754): at android.os.Handler.dispatchMessage(Handler.java:92)
03-02 18:54:12.285: E/AndroidRuntime(3754): at android.os.Looper.loop(Looper.java:137)
03-02 18:54:12.285: E/AndroidRuntime(3754): at android.app.ActivityThread.main(ActivityThread.java:5493)
03-02 18:54:12.285: E/AndroidRuntime(3754): at java.lang.reflect.Method.invokeNative(Native Method)
03-02 18:54:12.285: E/AndroidRuntime(3754): at java.lang.reflect.Method.invoke(Method.java:525)
03-02 18:54:12.285: E/AndroidRuntime(3754): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1209)
03-02 18:54:12.285: E/AndroidRuntime(3754): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1025)
03-02 18:54:12.285: E/AndroidRuntime(3754): at dalvik.system.NativeStart.main(Native Method)
可以看到的是,出现了NoSuchFieldError错误。
百思不得其解,后来终于找到了一个靠谱的说法:
是因为我在代码中解析JSON数据的时候,使用Jackson将JSON数据变成了JavaBean对象,导致代码在打包签名、混淆代码后,找不到原来对象的属性了。
故报错。
解决方法:
在proguard-project.txt中,加入不需要混淆的JavaBean对象和对Jackson的不需要混淆代码的语句
-libraryjars libs/jackson-core-asl-1.9.7.jar
-libraryjars libs/jackson-mapper-asl-1.9.7.jar
-keep public class org.codehaus.**{*;}
-keepclassmembers public class org.codehaus.**{*;}
-dontwarn org.codehaus.jackson.**
-keep class org.codehaus.**
-keepnames class org.codehaus.jackson.** { *; }
重新打包签名,问题解决。
参考资料:http://stackoverflow.com/questions/25284562/proguard-aws-s3-issue