我有一个使用使用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 已经存在。唯一的变化是数据库中的一些更多字段和一个表中的更多行。
我会为每一个提示感到高兴:-)