github大神解答:
https://github.com/sqlcipher/android-database-sqlcipher/issues/152
This is likely due to not properly including the native libraries with your application. Here is a tutorial on integrating the library with an Android application.
也就是你需要把libdatabase_sqlcipher.so 等一系列库copy到你的工程中
看源码发现需要的so库有
很关键的一点要在你的gradle中添加
sourceSets {
main {
jniLibs.srcDirs = ['libs']
}
}
错误提示信息
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.palmv.contactresmg, PID: 6043
java.lang.UnsatisfiedLinkError: Couldn't load stlport_shared from loader dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/com.palmv.contactresmg-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.palmv.contactresmg-1, /system/lib, /system/lib/arm]]]: findLibrary returned null
at java.lang.Runtime.loadLibrary(Runtime.java:358)
at java.lang.System.loadLibrary(System.java:526)
at net.sqlcipher.database.SQLiteDatabase.loadLibs(SQLiteDatabase.java:118)
at net.sqlcipher.database.SQLiteDatabase.loadLibs(SQLiteDatabase.java:113)
at com.palmv.networksalebox.contactresmg.db.EnWeChatDBHelper.<init>(EnWeChatDBHelper.java:35)
at com.palmv.networksalebox.contactresmg.db.EnWeChatDBHelper.getInstance(EnWeChatDBHelper.java:27)
at com.palmv.networksalebox.contactresmg.db.DBManagerEnMicroMsg.getCipherDB(DBManagerEnMicroMsg.java:106)
at com.palmv.networksalebox.contactresmg.db.DBManagerEnMicroMsg.<init>(DBManagerEnMicroMsg.java:56)
at com.palmv.networksalebox.contactresmg.db.DBManagerEnMicroMsg.newEnInstance(DBManagerEnMicroMsg.java:125)
at com.palmv.networksalebox.contactresmg.activity.MainActivity.onCreate(MainActivity.java:98)
at android.app.Activity.performCreate(Activity.java:5247)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2154)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2335)
at android.app.ActivityThread.access$800(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1202)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5103)
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 de.robv.android.xposed.XposedBridge.main(XposedBridge.java:132)
at dalvik.system.NativeStart.main(Native Method)
Application terminated.