在iOS模拟器和设备上测试NSFileProtectionComplete

7

我在一个CoreData应用程序中为我的-(NSPersistentStoreCoordinator *)persistentStoreCoordinator编写了这段代码。我使用了xCode的Master-Detail应用程序模板来创建该应用程序...

- (NSPersistentStoreCoordinator *)persistentStoreCoordinator
{
    if (__persistentStoreCoordinator != nil) {
        return __persistentStoreCoordinator;
    }

    NSURL *storeURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:@"Notes2.sqlite"];

    NSError *error = nil;
    __persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:[self managedObjectModel]];
    if (![__persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeURL options:nil error:&error]) {

        NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
        abort();
    }    

    NSString *urlString = [storeURL absoluteString];
    NSDictionary *fileAttributes = [NSDictionary dictionaryWithObject:NSFileProtectionComplete forKey:NSFileProtectionKey];
    if (![[NSFileManager defaultManager] setAttributes:fileAttributes ofItemAtPath:urlString error:&error]) 
    {
        // Handle error
    }


    return __persistentStoreCoordinator;
}

如何测试并知道我的SQLite已经开启了NSFileProtectionComplete保护?

我锁定了模拟器,但当我在Finder中双击该文件时,它仍然可读。


我也在设备上进行了测试,先锁定设备,然后使用iTunes和iTunes文件共享将文件从设备复制到我的桌面… 但是该文件仍可读取。 - OscarTheGrouch
1
你能测试这个吗? - yoninja
1个回答

0

iTunes不会从设备复制文件,除非它有您的密码或设备以前被信任;这就是它能够解密数据的原因。

在Xcode 8及更早版本中,模拟器使用主机文件系统,而macOS目前不支持与iOS相同的逐个文件加密,因此在macOS上无法在模拟器中测试此功能。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接