获取的NoClassDefFoundError尝试使用ProGuard,并将SQLcipher Android中 [英] Getting NoClassDefFoundError while trying to use Proguard and SQLcipher in Android

查看:663
本文介绍了获取的NoClassDefFoundError尝试使用ProGuard,并将SQLcipher Android中的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我得到一个 ava.lang.NoClassDefFoundError:网/ sqlcipher / CursorWindow 试图运行使用sqlicipher和ProGuard的我的应用程序时。该项目工程完全未启用ProGuard的。我第一次用sqlcipher创建一个新的数据库,我得到上述错误。我已经看过另一个SO问题,那就是看似相同,但我试图从这个问题的答案,我仍然得到错误。

<一个href=\"http://stackoverflow.com/questions/21094048/android-proguard-sqlcipher-noclassdeffounderror\">Android Proguard的SqlCipher的NoClassDefFoundError

下面是我的整个 proguard相关的属性

  -libraryjars库/ commons- codec.jar
-libraryjars库/番石榴r09.jar
-libraryjars库/ httpmime-4.1.2.jar
-libraryjars库/ jsr305-2.0.2.jar
-libraryjars库/ libphonenumber-5.7.jar
-libraryjars库/ sqlcipher.jar
-keep类com.myandroidapp ** {*。 }
-optimizationpasses 5
-dontusemixedcaseclassnames
-dontskipnonpubliclibraryclasses
-dontskipnonpubliclibraryclassmembers
-dont preverify
-dontobfuscate
-verbose
-optimizations!code /简化/算术!现场/ * ,!类/合并/ *!code /配置/变量-keep公共类*扩展android.app.Activity
-keep公共类*扩展android.app.Application-dontwarn javax.annotation中。**-dontwarn android.app。**
-dontwarn android.support。**
-dontwarn android.view。**
-dontwarn android.widget。**-dontwarn com.google.common.primitives。**-dontwarn ** CompatHoneycomb
-dontwarn ** CompatHoneycombMR2
-dontwarn ** CompatCreatorHoneycombMR2-keepclasseswithmembernames类* {
    天然的所述;方法&gt ;;
}-keepclasseswithmembers类* {
    公众和LT; INIT&GT;(android.content.Context,android.util.AttributeSet);
}-keepclasseswithmembers类* {
    公众和LT; INIT&GT;(android.content.Context,android.util.AttributeSet,INT);
}-keepclassmembers类*宽android.app.Activity {
   公共无效*(android.view.View);
}-keepclassmembers枚举* {
    公共静态** []值();
    公共静态**的valueOf(java.lang.String中);
}-keep类*实现android.os.Parcelable {
  公共静态最终android.os.Parcelable $造物主*;
}-keepclassmembers类**。R $ * {
    公共静态&LT;领域取代;
}-keep公共类net.sqlcipher。** {
    *;
}-keep公共类net.sqlcipher.database。** {
    *;
}

错误消息:

  01-22 19:18:26.553:W / dalvikvm(18993):抛出异常(Ljava /朗/ NoSuchFieldError;),而抛出内部异常(Ljava /朗/ NoSuchFieldError;)
01-22 19:18:26.553:E /光标(18993):错误定位领域
01-22 19:18:26.553:E /光标(18993):找不到网/ sqlcipher /数据库/ SQLiteQuery
01-22 19:18:26.553:E /光标(18993):找不到网/ sqlcipher /数据库/ SQLiteProgram
01-22 19:18:26.553:E /光标(18993):找不到网/ sqlcipher /数据库/ SQLiteStatement
01-22 19:18:26.553:E / CursorWindow(18993):找不到网/ sqlcipher / CursorWindow
01-22 19:18:26.553:D / AndroidRuntime(18993):关闭VM
01-22 19:18:26.553:W / dalvikvm(18993):主题ID = 1:螺纹未捕获的异常退出(组= 0x41570c80)
:E / AndroidRuntime(18993):致命异常:主要
:E / AndroidRuntime(18993):工艺:com.myandroidapp.androidapp,PID:18993
:E / AndroidRuntime(18993):java.lang.NoClassDefFoundError的:净/ sqlcipher / CursorWindow
:E / AndroidRuntime(18993):在java.lang.Runtime.nativeLoad(本机方法)
:E / AndroidRuntime(18993):在java.lang.Runtime.doLoad(Runtime.java:421)
:E / AndroidRuntime(18993):在java.lang.Runtime.loadLibrary(Runtime.java:362)
:E / AndroidRuntime(18993):在java.lang.System.loadLibrary(System.java:526)
:E / AndroidRuntime(18993):在net.sqlcipher.database.SQLiteDatabase.loadLibs(来源不明)
:E / AndroidRuntime(18993):在net.sqlcipher.database.SQLiteDatabase.loadLibs(来源不明)
:E / AndroidRuntime(18993):在com.myandroidapp.androidapp.androidappDBAdapter.initializeDB(来源不明)
:E / AndroidRuntime(18993):在com.myandroidapp.services.CompleteService $ androidappCompleteThread $ 2.onResponse(来源不明)
:E / AndroidRuntime(18993):在com.myandroidapp.services.CompleteService $ androidappCompleteThread $ 2.onResponse(来源不明)
:E / AndroidRuntime(18993):在com.myandroidapp.androidapp.androidappHtt prequest.deliverResponse(来源不明)
:E / AndroidRuntime(18993):在com.myandroidapp.androidapp.androidappHtt prequest.deliverResponse(来源不明)
:E / AndroidRuntime(18993):在com.android.volley.i.run(来源不明)
:E / AndroidRuntime(18993):在android.os.Handler.handleCallback(Handler.java:733)
:E / AndroidRuntime(18993):在android.os.Handler.dispatchMessage(Handler.java:95)
:E / AndroidRuntime(18993):在android.os.Looper.loop(Looper.java:136)
:E / AndroidRuntime(18993):在android.app.ActivityThread.main(ActivityThread.java:5081)
:E / AndroidRuntime(18993):在java.lang.reflect.Method.invokeNative(本机方法)
:E / AndroidRuntime(18993):在java.lang.reflect.Method.invoke(Method.java:515)
:E / AndroidRuntime(18993):在com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:781)
:E / AndroidRuntime(18993):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
:E / AndroidRuntime(18993):在dalvik.system.NativeStart.main(本机方法)
:E / AndroidRuntime(18993):java.lang.NoClassDefFoundError的:致网/ sqlcipher /数据库/ SQLiteStatement
:E / AndroidRuntime(18993):...... 21多
:E / AndroidRuntime(18993):java.lang.NoClassDefFoundError的:致网/ sqlcipher /数据库/ SQLiteProgram
:E / AndroidRuntime(18993):...... 21多
:E / AndroidRuntime(18993):java.lang.NoClassDefFoundError的:致网/ sqlcipher /数据库/ SQLiteQuery
:E / AndroidRuntime(18993):...... 21多
:E / AndroidRuntime(18993):java.lang.NoSuchFieldError:产生的原因与名称的字段='nHandle'签名='我'类LNET / sqlcipher /数据库/ SQLiteCompiledSql;
:E / AndroidRuntime(18993):...... 21多


解决方案

我认为类是由Proguard的收缩工具取出。

尝试添加下面的参数

  -dontshrink

和告诉我,如果它的工作原理。

我也看到了一个属性是在一个受保护类Sqlcipher的丢失:

 :E / AndroidRuntime(18993):java.lang.NoSuchFieldError:产生的原因与名称的字段='nHandle'签名='我'类LNET / sqlcipher /数据库/ SQLiteCompiledSql;

你能不能也尽量保持保护等级从Sqlcipher?

  -keep类net.sqlcipher。** {
    *;
}

P.S是不是正规,你有你的配置选项-dontobfuscate?如果你让你的申请将不被混淆。

I am getting a ava.lang.NoClassDefFoundError: net/sqlcipher/CursorWindow when trying to run my app using sqlicipher and proguard. The project works perfectly without proguard enabled. The first time I use sqlcipher to create a new db I get the error above. I have looked at another SO question that is seemingly identical, but I have tried the answers from that question and I'm still getting the error.

Android Proguard SqlCipher NoClassDefFoundError

Here is my entire proguard-properties:

-libraryjars libs/commons-codec.jar
-libraryjars libs/guava-r09.jar
-libraryjars libs/httpmime-4.1.2.jar
-libraryjars libs/jsr305-2.0.2.jar
-libraryjars libs/libphonenumber-5.7.jar
-libraryjars libs/sqlcipher.jar
-keep class com.myandroidapp.** { *; }


-optimizationpasses 5
-dontusemixedcaseclassnames
-dontskipnonpubliclibraryclasses
-dontskipnonpubliclibraryclassmembers
-dontpreverify
-dontobfuscate
-verbose
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*,!code/allocation/variable

-keep public class * extends android.app.Activity
-keep public class * extends android.app.Application

-dontwarn javax.annotation.**

-dontwarn android.app.**
-dontwarn android.support.**
-dontwarn android.view.**
-dontwarn android.widget.**

-dontwarn com.google.common.primitives.**

-dontwarn **CompatHoneycomb
-dontwarn **CompatHoneycombMR2
-dontwarn **CompatCreatorHoneycombMR2

-keepclasseswithmembernames class * {
    native <methods>;
}

-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.app.Activity {
   public void *(android.view.View);
}

-keepclassmembers enum * {
    public static **[] values();
    public static ** valueOf(java.lang.String);
}

-keep class * implements android.os.Parcelable {
  public static final android.os.Parcelable$Creator *;
}

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

-keep public class net.sqlcipher.** {
    *;
}

-keep public class net.sqlcipher.database.** {
    *;
}

Error message:

01-22 19:18:26.553: W/dalvikvm(18993): Exception thrown (Ljava/lang/NoSuchFieldError;) while throwing internal exception (Ljava/lang/NoSuchFieldError;)
01-22 19:18:26.553: E/Cursor(18993): Error locating fields
01-22 19:18:26.553: E/Cursor(18993): Can't find net/sqlcipher/database/SQLiteQuery
01-22 19:18:26.553: E/Cursor(18993): Can't find net/sqlcipher/database/SQLiteProgram
01-22 19:18:26.553: E/Cursor(18993): Can't find net/sqlcipher/database/SQLiteStatement
01-22 19:18:26.553: E/CursorWindow(18993): Can't find net/sqlcipher/CursorWindow
01-22 19:18:26.553: D/AndroidRuntime(18993): Shutting down VM
01-22 19:18:26.553: W/dalvikvm(18993): threadid=1: thread exiting with uncaught exception (group=0x41570c80)
: E/AndroidRuntime(18993): FATAL EXCEPTION: main
: E/AndroidRuntime(18993): Process: com.myandroidapp.androidapp, PID: 18993
: E/AndroidRuntime(18993): java.lang.NoClassDefFoundError: net/sqlcipher/CursorWindow
: E/AndroidRuntime(18993):  at java.lang.Runtime.nativeLoad(Native Method)
: E/AndroidRuntime(18993):  at java.lang.Runtime.doLoad(Runtime.java:421)
: E/AndroidRuntime(18993):  at java.lang.Runtime.loadLibrary(Runtime.java:362)
: E/AndroidRuntime(18993):  at java.lang.System.loadLibrary(System.java:526)
: E/AndroidRuntime(18993):  at net.sqlcipher.database.SQLiteDatabase.loadLibs(Unknown Source)
: E/AndroidRuntime(18993):  at net.sqlcipher.database.SQLiteDatabase.loadLibs(Unknown Source)
: E/AndroidRuntime(18993):  at com.myandroidapp.androidapp.androidappDBAdapter.initializeDB(Unknown Source)
: E/AndroidRuntime(18993):  at com.myandroidapp.services.CompleteService$androidappCompleteThread$2.onResponse(Unknown Source)
: E/AndroidRuntime(18993):  at com.myandroidapp.services.CompleteService$androidappCompleteThread$2.onResponse(Unknown Source)
: E/AndroidRuntime(18993):  at com.myandroidapp.androidapp.androidappHttpRequest.deliverResponse(Unknown Source)
: E/AndroidRuntime(18993):  at com.myandroidapp.androidapp.androidappHttpRequest.deliverResponse(Unknown Source)
: E/AndroidRuntime(18993):  at com.android.volley.i.run(Unknown Source)
: E/AndroidRuntime(18993):  at android.os.Handler.handleCallback(Handler.java:733)
: E/AndroidRuntime(18993):  at android.os.Handler.dispatchMessage(Handler.java:95)
: E/AndroidRuntime(18993):  at android.os.Looper.loop(Looper.java:136)
: E/AndroidRuntime(18993):  at android.app.ActivityThread.main(ActivityThread.java:5081)
: E/AndroidRuntime(18993):  at java.lang.reflect.Method.invokeNative(Native Method)
: E/AndroidRuntime(18993):  at java.lang.reflect.Method.invoke(Method.java:515)
: E/AndroidRuntime(18993):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:781)
: E/AndroidRuntime(18993):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
: E/AndroidRuntime(18993):  at dalvik.system.NativeStart.main(Native Method)
: E/AndroidRuntime(18993): Caused by: java.lang.NoClassDefFoundError: net/sqlcipher/database/SQLiteStatement
: E/AndroidRuntime(18993):  ... 21 more
: E/AndroidRuntime(18993): Caused by: java.lang.NoClassDefFoundError: net/sqlcipher/database/SQLiteProgram
: E/AndroidRuntime(18993):  ... 21 more
: E/AndroidRuntime(18993): Caused by: java.lang.NoClassDefFoundError: net/sqlcipher/database/SQLiteQuery
: E/AndroidRuntime(18993):  ... 21 more
: E/AndroidRuntime(18993): Caused by: java.lang.NoSuchFieldError: no field with name='nHandle' signature='I' in class Lnet/sqlcipher/database/SQLiteCompiledSql;
: E/AndroidRuntime(18993):  ... 21 more

解决方案

I think that the class was removed by the Proguard Shrinking tool.

Try to add the following parameter

-dontshrink

and tell me if it works.

I also saw that an attribute is missing in a protected class of Sqlcipher :

: E/AndroidRuntime(18993): Caused by: java.lang.NoSuchFieldError: no field with name='nHandle' signature='I' in class Lnet/sqlcipher/database/SQLiteCompiledSql;

Can you also try to keep protected classes from Sqlcipher ?

-keep class net.sqlcipher.** {
    *;
}

P.S Is it regular that you have the option -dontobfuscate in your configuration ? Your application will not be obfuscated if you keep it.

这篇关于获取的NoClassDefFoundError尝试使用ProGuard,并将SQLcipher Android中的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆