0

我有一个使用使用SQLCipher加密的数据库的应用程序。一切正常。但是现在我在数据库中添加了一些数据。之前大约是 1.4 MB,现在大约是 6 MB。尝试使用新数据库运行相同的应用程序会产生以下错误:

06-10 17:20:31.819: E/Database(3821): CREATE TABLE android_metadata failed
06-10 17:20:31.889: E/Database(3821): Failed to setLocale() when constructing, closing the database
06-10 17:20:31.889: E/Database(3821): info.guardianproject.database.sqlcipher.SQLiteDatabaseCorruptException: database disk image is malformed
06-10 17:20:31.889: E/Database(3821):   at info.guardianproject.database.sqlcipher.SQLiteDatabase.native_setLocale(Native Method)
06-10 17:20:31.889: E/Database(3821):   at info.guardianproject.database.sqlcipher.SQLiteDatabase.setLocale(SQLiteDatabase.java:2015)
06-10 17:20:31.889: E/Database(3821):   at info.guardianproject.database.sqlcipher.SQLiteDatabase.<init>(SQLiteDatabase.java:1881)
06-10 17:20:31.889: E/Database(3821):   at info.guardianproject.database.sqlcipher.SQLiteDatabase.openDatabase(SQLiteDatabase.java:864)

但就像在旧版本的数据库中,表 android_metadata 已经存在。唯一的变化是数据库中的一些更多字段和一个表中的更多行。

我会为每一个提示感到高兴:-)

4

1 回答 1

0

根据堆栈跟踪中的包名称,您似乎正在使用旧版本的 SQLCipher for Android 库。您可以考虑升级到此处提供的最新版本的库。此外,您应该尝试在桌面上本地打开数据库,以验证文件没有损坏。

于 2013-06-11T15:05:07.200 回答