1

私はしばらくの間、問題なくアプリをテストしてきました。しかし、今日、myTouch4GのT-Mobileからシステムアップデートを受け取りました。SQLCipherを使用する私のアプリは、開いたときに次のエラーでクラッシュするようになりました。

01-23 20:43:37.200 E/AndroidRuntime(5534): FATAL EXCEPTION: main
01-23 20:43:37.200 E/AndroidRuntime(5534): java.lang.UnsatisfiedLinkError: Cannot load library: reloc_library[1312]:  1235 cannot locate 'ucol_strcollIter_4_2'...
01-23 20:43:37.200 E/AndroidRuntime(5534): 
01-23 20:43:37.200 E/AndroidRuntime(5534):  at java.lang.Runtime.load(Runtime.java:394)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at java.lang.System.load(System.java:534)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at info.guardianproject.database.sqlcipher.SQLiteDatabase.loadLibs(SQLiteDatabase.java:123)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at com.app.myapp.datamanagement.DatabaseManager.open(DatabaseManager.java:62)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at com.app.myapp.datamanagement.DatabaseManager.<init>(DatabaseManager.java:58)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at com.app.myapp.datamanagement.DataManager.establishDatabase(DataManager.java:45)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at com.app.myapp.service.MainActivity.onCreate(NoteEditorDialogActivity.java:44)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1093)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1891)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1960)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.app.ActivityThread.access$1500(ActivityThread.java:145)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1045)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.os.Handler.dispatchMessage(Handler.java:99)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.os.Looper.loop(Looper.java:150)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at android.app.ActivityThread.main(ActivityThread.java:4369)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at java.lang.reflect.Method.invokeNative(Native Method)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at java.lang.reflect.Method.invoke(Method.java:507)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:846)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:604)
01-23 20:43:37.200 E/AndroidRuntime(5534):  at dalvik.system.NativeStart.main(Native Method)

このエラーをデバッグ目的で保持する必要があったため、アプリの再インストールはまだ試していませんが、この問題は修正されると確信しています。ただし、このエラーが発生している理由と、それを防ぐ方法を知っておく必要があります。そうすれば、アプリを公開するときに、他の人がこの致命的なクラッシュを経験することはありません。

注:システムアップデートは、アップデートの前後に2.3.4のままだったため、マイナーなもののようでした。

4

2 に答える 2

1

依存関係のdllが欠落しているようです(あなたの場合は'ucol_strcollIter_4_2' ....)。これがこのエラーに関するSOの議論です。

于 2012-01-24T05:02:29.740 に答える
0

まず、この質問をSQLCipher Googleグループに投稿する必要があります:http://groups.google.com/group/sqlcipher

次に、11月からのSQLCipher v1、別名0.0.6の最終リリースを使用していますか?https://github.com/downloads/sqlcipher/android-database-sqlcipher/SQLCipherForAndroid-SDK-0.0.6-FINAL.zip

特定の内部ライブラリへのリンクに関連する問題が発生しているようです。これは、Android用のSQLCipherの以前のバージョンでより一般的でした。

Androidマーケットの「NoteCipher」アプリを試してみてください。SQLCipherも含まれているので、それが機能するかどうかもお知らせください。

于 2012-01-24T05:40:17.020 に答える