sqlite шифрование / дешифрование + sqlcipher + iPhone
Я пытался зашифровать / расшифровать базу данных sqlite в моем проекте iPhone. Я могу зашифровать базу данных с помощью метода reKey. Но я не могу расшифровать это. Я сохранил свой файл sqlite.db в папке. В данный момент пробую это на симуляторе.
Фрагмент кода:
[[SQLiteDB sharedSQLiteDB] open:<path to the folder> withKey:@""];
[[SQLiteDB sharedSQLiteDB] reKey:@"abc"];
[[SQLiteDB sharedSQLiteDB] close];
[[SQLiteDB sharedSQLiteDB] open:<path to the folder> withKey:@"abc"];
[[SQLiteDB sharedSQLiteDB] reKey:@""];
.....
- (BOOL)open:(NSString *)path withKey:(NSString *)masterKey {
if (sqlite3_open([path fileSystemRepresentation], &_db) != SQLITE_OK) {
NSLog(@"SQLite Opening Error: %s", sqlite3_errmsg(_db));
return NO;
}
if(masterKey)
sqlite3_exec(_db, [[NSString stringWithFormat:@"PRAGMA key = '%@'", masterKey] UTF8String], NULL, NULL, NULL);
if (sqlite3_exec(_db, (const char*) "SELECT count(*) FROM sqlite_master", NULL, NULL, NULL) != SQLITE_OK)
{
[self close];
NSLog(@"SQLite Key Error!");
return NO;
}
filePath = [path retain];
return YES;
}
......
- (void)reKey:(NSString *)masterKey
{
sqlite3_exec(_db, [[NSString stringWithFormat:@"PRAGMA rekey = '%@'", masterKey] UTF8String], NULL, NULL, NULL);
}
Я прочитал сообщения на эту тему в группах Google sqlcipher, но не могу расшифровать его. Любая помощь будет высоко оценен.
1 ответ
Перепечатка из списка рассылки:
Если вы пытаетесь взять существующую незашифрованную базу данных, зашифровать ее, а затем расшифровать, то мы рекомендуем не использовать повторный ключ, а вместо этого использовать базы данных ATTACH для копирования данных между стандартной базой данных и базой данных sqlcipher. Здесь есть больше информации и конкретный пример:
http://www.zetetic.net/blog/2009/12/29/how-to-encrypt-a-plaintext-sqlite-database-to-use-sqlcipher/
Если вместо этого вы просто пытаетесь использовать sqlcipher для шифрования данных в целом (т.е. без преобразования из ранее существующей базы данных), то вам просто нужно использовать sqlite3_key. Вы просто открываете базу данных, предоставляете ключ и затем делаете вызовы sql. Не существует отдельных этапов шифрования / дешифрования - все это обрабатывается на лету кодом sqlcipher. В коде, который вы разместили ранее, вы никогда не будете вызывать rekey вообще. Каждый раз, когда вы открываете базу данных, вы вызываете ключ PRAGMA, а затем запускаете быструю проверку, чтобы убедиться, что sqlite_master доступен для чтения.