ios – SQLCipher和CoreData问题:CoreData无法完成故障

前端之家收集整理的这篇文章主要介绍了ios – SQLCipher和CoreData问题:CoreData无法完成故障前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个与sqlCipher数据库加密和CoreData的问题:
当我使用持久性存储协调器与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在内部使用这样的属性,并且与它冲突.一旦我把它重新命名为另一个名字,一切正常!

猜你在找的iOS相关文章