Я пытаюсь зашифровать данные, хранящиеся в моем поставщике контента, с обновлением приложения. Я последовал за ссылку ниже для этого
How to implement SQLCipher when using SQLiteOpenHelper
Обновление данных поставщика контента (с поддержкой SQLite) для шифрования с использованием SQLCipher -Android
Хотя это отлично работает, если новая установка не будет сделана, если я иду на обновление, приложение падает с ниже ошибками
net.sqlcipher.database.SQLiteException: file is encrypted or is not a database
at android.app.ActivityThread.handleReceiver(ActivityThread.java:3009)
at android.app.ActivityThread.access$1800(ActivityThread.java:177)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1526)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:145)
at android.app.ActivityThread.main(ActivityThread.java:5951)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1388)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1183)
Caused by: net.sqlcipher.database.SQLiteException: file is encrypted or is not a database
Я даже попытался удалить существующие таблицы и создать новую таблицу, чтобы убедиться, что это решило проблему, но это тоже не помогло. Пожалуйста, подсказывают, как это исправить, Мой класс Helper, как показано ниже,
public class MyDBHelper extends SQLiteOpenHelper {
public MyDBHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
SQLiteDatabase.loadLibs(context);
}
public static final String DATABASE_NAME = "mydb.db";
private static final int DATABASE_VERSION = 2; // before attempting encryption it was 1
@Override
public void onCreate(SQLiteDatabase db) {
createTables(db);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("DROP TABLE IF EXISTS " + "TEST_TABLE");
createTables(db);
}
private void createTables(SQLiteDatabase db){
db.execSQL(MyDBQueries.CREATE_TEST_TABLE);
}
}
Мой обновленный провайдер просто использует ключ теперь, чтобы открыть БД, как показано ниже,
SQLiteDatabase db = databaseHelper.getWritableDatabase("encryptionKey");
Как я упомянутые, свежие установки работают хорошо, но обновление приводит к сбою приложения. Пожалуйста, предложите, как это исправить.
Вы обновляете базу данных, которая уже зашифрована? Или вы обновляетесь из базы данных, которая еще не зашифрована? BTW, в будущем, пожалуйста, разместите всю трассировку стека. – CommonsWare
База данных не зашифрована изначально, я хочу, чтобы она была зашифрована с обновлением приложения. – Kaps