コアデータを暗号化するためにEncryptedStore SQLCipher wrapperに問題があります。
私は、このためのC-フラグを追加しました:XCode9-beta:関数 'sqlite3_key'の暗黙的な宣言
Debug = -DSQLITE_HAS_CODEC -DSQLITE_TEMP_STORE=2 -DSQLITE_THREADSAFE -DSQLCIPHER_CRYPTO_CC
Release = -DSQLITE_HAS_CODEC -DNDEBUG -DSQLITE_OS_UNIX=1 -DSQLITE_TEMP_STORE=2 -DSQLITE_THREADSAFE -DSQLCIPHER_CRYPTO_CC
としてそれを使用する:それはXCode8で正常に動作しているが、それはXCode9ベータにエラーを与えている
func encryptedCoordinator() -> NSPersistentStoreCoordinator {
var coordinator:NSPersistentStoreCoordinator?
let ops:[String : Any] = [NSMigratePersistentStoresAutomaticallyOption:(true), NSInferMappingModelAutomaticallyOption:(true), EncryptedStorePassphraseKey:sqlCipherKey, EncryptedStoreDatabaseLocation:self.sqliteFileURL()]
do {
coordinator = try EncryptedStore.make(options: ops, managedObjectModel: self.managedObjectModel, error:())
}catch {
fatalError("Error opening encrypted DB: \(error)")
}
return coordinator!
}
。
エラー行:
- (BOOL)changeDatabasePassphrase:(NSString *)passphrase error:(NSError *__autoreleasing*)error {
BOOL result;
int status;
if ([passphrase length] > 0) {
// Password provided, use it to key the DB
const char *string = [passphrase UTF8String];
status = sqlite3_rekey(database, string, (int)strlen(string));//ERROR line
string = NULL;
passphrase = nil;
} else {
// No password
status = SQLITE_OK;
}
result = status == SQLITE_OK;
if (result) {
result = [self checkDatabaseStatusWithError:error];
}
return result && (*error == nil);
}
機能としてEncryptedStroe/sqlite3.h
に宣言されています。私は問題があると思い
SQLITE_API int sqlite3_rekey(
sqlite3 *db, /* Database to be rekeyed */
const void *pKey, int nKey /* The new key */
);
SQLITE_API int sqlite3_rekey_v2(
sqlite3 *db, /* Database to be rekeyed */
const char *zDbName, /* Name of the database */
const void *pKey, int nKey /* The new key */
);
を、私はこれはGitHubの – D4ttatraya