Обновление данных поставщика простого контента с помощью SQLite до SQLCipherAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Обновление данных поставщика простого контента с помощью SQLite до SQLCipher

Сообщение Anonymous »

Я пытаюсь зашифровать данные, хранящиеся у моего поставщика контента, с помощью обновления приложения. Я следил за тем,
Как реализовать SQLCipher при использовании SQLiteOpenHelper?. Хотя это работает при новой установке, если я обновлю приложение, оно выйдет из строя:
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

Удаление существующих таблиц и создание новых не помогло. Как мне это исправить? Класс MyDBHelper:
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");


Подробнее здесь: https://stackoverflow.com/questions/348 ... -sqlcipher
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»