Прикрепить базу данных для SQLCIPHER - PullRequest
0 голосов
/ 06 декабря 2010

У меня было много проблем с шифрованием базы данных SQLITE для моего проекта, и, наконец, я пытаюсь использовать метод присоединения базы данных для шифрования моей незашифрованной базы данных.

Я попытался запустить команду присоединения на Терминале, только чтобы понять, что выводом будет незашифрованная база данных. Так что по праву я должен запускать команды в моем проекте с импортированными библиотеками sqlcipher и ssl, верно?

Итак, я попробовал, метод работает без сбоев, но я даже не смог создать зашифрованную базу данных в каталоге документов. Что я делаю неправильно? [Фрагмент кода ниже]

 - (void)encryptDB
{
  NSLog (@"Start");
  sqlite3 *DB = [iPad_3AppDelegate getNewDBConnection];

  sqlite3_exec(DB, "ATTACH DATABASE KeyCryptENC.db AS encrypted KEY 1234;", NULL, NULL, NULL);

  sqlite3_exec(DB, "CREATE TABLE encrypted.Account(A_id,C_ID,Account_Name,Username,Password,Other_Information);", NULL, NULL, NULL);
  sqlite3_exec(DB, "CREATE TABLE encrypted.Categories(C_ID,Category);", NULL, NULL, NULL);
  sqlite3_exec(DB, "CREATE TABLE encrypted.UserInfo(Password,Hint,Secret_Question,Secret_Answer);", NULL, NULL, NULL);

  sqlite3_exec(DB, "INSERT INTO encrypted.Account SELECT * FROM Account;", NULL, NULL, NULL);
  sqlite3_exec(DB, "INSERT INTO encrypted.Categories SELECT * FROM Categories;", NULL, NULL, NULL);
  sqlite3_exec(DB, "INSERT INTO encrypted.UserInfo SELECT * FROM UserInfo;", NULL, NULL, NULL);

  sqlite3_exec(DB, "DETACH DATABASE encrypted;", NULL, NULL, NULL);

  NSLog (@"End");

}

+ (sqlite3 *)getNewDBConnection{
  sqlite3 *newDBconnection;
  NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
  NSString *documentsDirectory = [paths objectAtIndex:0];
  NSString *path = [documentsDirectory stringByAppendingPathComponent:@"KeyCrypt.sqlite"];
  // Open the database. The database was prepared outside the application.
  if (sqlite3_open([path UTF8String], &newDBconnection) == SQLITE_OK) {
    NSLog(@"Database Successfully Opened :)");
  } else {
    NSLog(@"Error in opening database :(");
  } 
  return newDBconnection; 
} 

Большое спасибо за помощь, ребята!

1 Ответ

1 голос
/ 09 декабря 2010

после более интенсивных исследований я понял проблему с шифрованием, ME.Я использовал Mac OS X родной sqlite3.И да, эта ссылка должна помочь всем, кто сталкивается с проблемой, похожей на мою.

BWAHAHA, мне так глупо, что я не думал об этом раньше.

...