2016-03-02 64 views
0

我的应用程序工作正常,没有应用保护规则,但出于安全目的,我必须在我的应用程序中应用保护规则。 我在应用规则并尝试运行我的应用程序时遇到了这些错误。Android应用程序崩溃与proguard规则

FATAL EXCEPTION: main 
                    Process: com.nearely.nearelysales, PID: 4275 
                    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.nearely.nearelysales/com.nearely.nearelysales.activities.MainActivity}: java.lang.NullPointerException 
                     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2184) 
                     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2233) 
                     at android.app.ActivityThread.access$800(ActivityThread.java:135) 
                     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 
                     at android.os.Handler.dispatchMessage(Handler.java:102) 
                     at android.os.Looper.loop(Looper.java:136) 
                     at android.app.ActivityThread.main(ActivityThread.java:5001) 
                     at java.lang.reflect.Method.invokeNative(Native Method) 
                     at java.lang.reflect.Method.invoke(Method.java:515) 
                     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785) 
                     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601) 
                     at dalvik.system.NativeStart.main(Native Method) 
                    Caused by: java.lang.NullPointerException 
                     at com.nearely.nearelysales.activities.MainActivity.k(Unknown Source) 
                     at com.nearely.nearelysales.activities.MainActivity.onCreate(Unknown Source) 
                     at android.app.Activity.performCreate(Activity.java:5231) 
                     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 
                     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2148) 
                     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2233)  
                     at android.app.ActivityThread.access$800(ActivityThread.java:135)  
                     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)  
                     at android.os.Handler.dispatchMessage(Handler.java:102)  
                     at android.os.Looper.loop(Looper.java:136)  
                     at android.app.ActivityThread.main(ActivityThread.java:5001)  
                     at java.lang.reflect.Method.invokeNative(Native Method)  
                     at java.lang.reflect.Method.invoke(Method.java:515)  
                     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)  
                     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)  
                     at dalvik.system.NativeStart.main(Native Method)   

这里是我的progurd规则文件:

proguard-rules.pro

-injars  libs 
-outjars  bin/classes-processed.jar 
# -libraryjars C:\dev\android-sdk\platforms\android-23\android.jar 

-dontpreverify 
-repackageclasses '' 
-allowaccessmodification 
-optimizations !code/simplification/arithmetic 
-keepattributes *Annotation* 

-keep public class * extends android.app.Activity 
-keep public class * extends android.app.Application 
-keep public class * extends android.app.Service 
-keep public class * extends android.content.BroadcastReceiver 
-keep public class * extends android.content.ContentProvider 

-keep public class * extends android.view.View { 
    public <init>(android.content.Context); 
    public <init>(android.content.Context, android.util.AttributeSet); 
    public <init>(android.content.Context, android.util.AttributeSet, int); 
    public void set*(...); 
} 

-keepclasseswithmembers class * { 
    public <init>(android.content.Context, android.util.AttributeSet); 
} 

-keepclasseswithmembers class * { 
    public <init>(android.content.Context, android.util.AttributeSet, int); 
} 

-keepclassmembers class * extends android.content.Context { 
    public void *(android.view.View); 
    public void *(android.view.MenuItem); 
} 

-keepclassmembers class * implements android.os.Parcelable { 
    static ** CREATOR; 
} 

-keepclassmembers class **.R$* { 
    public static <fields>; 
} 

-keepclassmembers class * { 
    @android.webkit.JavascriptInterface <methods>; 
} 

-dontwarn butterknife.internal.** 
-keep class **$$ViewInjector { *; } 
-keepnames class * { @butterknife.InjectView *;} 

-keep class javax.ws.rs.** { *; } 
-dontwarn org.immutables.gson.** 

-dontwarn android.test.** 
-dontwarn org.junit.** 
+0

从您的日志中可以清楚地看到崩溃发生在'MainActivity'中。确保你已经为你正在使用的所有图书馆添加了专业排除。检查您是否排除了在MainActivity中使用的库 –

+0

@MuchOverflow我只在MainActivity中使用了Volley库。我应该排除哪些内容?你能给我个建议吗? – DhavalThakor

+2

检查这个帖子http://stackoverflow.com/questions/21816643/volley-seems-not-working-after-proguard-obfuscate – AndroidRuntimeException

回答

4

好像你已经使用截击和使用ProGuard崩溃您的应用程序。 您可以将此行写入您的proGuard

-keep class org.apache.commons.logging.**