我有一个与sqlCipher数据库加密和CoreData的问题:
当我使用持久性存储协调器与sqlCipher,它总是崩溃与故障一对多的关系,在第一个应用程序重新启动后.
所以当我第一次启动应用程序时,我创建了具有关系的NSManagedobjects,然后,当我保存db并重新打开应用程序时,当我尝试访问这些关系时,它会崩溃.
没有sqlCipher一切工作正常.
当我使用持久性存储协调器与sqlCipher,它总是崩溃与故障一对多的关系,在第一个应用程序重新启动后.
所以当我第一次启动应用程序时,我创建了具有关系的NSManagedobjects,然后,当我保存db并重新打开应用程序时,当我尝试访问这些关系时,它会崩溃.
没有sqlCipher一切工作正常.
以下是sqlCipher持久存储初始化的代码:
- (NSPersistentStoreCoordinator *)persistentStoreCoordinator { if (!_persistentStoreCoordinator) { NSURL *storeURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:@"MyApp.sqlite"]; NSDictionary *options = @{EncryptedStorePassphraseKey: @"MyApp",EncryptedStoreDatabaseLocation: storeURL}; NSError *error; _persistentStoreCoordinator = [EncryptedStore makeStoreWithOptions:options managedobjectModel:[self managedobjectModel] error:&error]; if (error) { NSLog(@"%@",error); } } return _persistentStoreCoordinator; }
我创建NSManagedobject的代码:
- (id)createObjectWithClassName:(Nsstring *)name { NSManagedobject *object = [[NSClassFromString(name) alloc] initWithEntity:[NSEntityDescription entityForName:name inManagedobjectContext:self.context] insertIntoManagedobjectContext:self.context]; return object; }
解决方法
最后我自己找到答案.
我调查不同的情况,并认为,这个问题只发生在我的数据模型中.
问题是我在NSManagedobject类中有一个名称为“index”的属性.
看来sqlCipher在内部使用这样的属性,并且与它冲突.一旦我把它重新命名为另一个名字,一切正常!