[英]Persisting bookmark in core-data
我有一个OSX应用程序,该应用程序应该具有用户磁盘中任何位置的文件列表。
该应用程序的第一个版本将这些文件的路径保存在核心数据模型中。
但是,如果文件被移动或重命名,该工具将失去其用途,并且应用程序可能会崩溃。
因此,我决定使用书签。 它似乎正在工作,但是每次我尝试恢复数据时,都会得到文件的旧路径。 这是为什么? 我想念什么?
我的核心数据实体使用二进制数据字段来保留书签。
书签本身是这样完成的:
NSData * bookmark = [filePath bookmarkDataWithOptions:NSURLBookmarkCreationMinimalBookmark
includingResourceValuesForKeys:NULL
relativeToURL:NULL
error:NULL];
在加载应用程序时,我有一个循环来迭代所有表并像这样恢复书签:
while (object = [rowEnumerator nextObject]) {
NSError * error = noErr;
NSURL * bookmark = [NSURL URLByResolvingBookmarkData:[object fileBookmark]
options:NSURLBookmarkResolutionWithoutUI
relativeToURL:NULL
bookmarkDataIsStale:NO
error:&error];
if (error != noErr)
DDLogCError(@"%@", [error description]);
DDLogCInfo(@"File Path: %@", [bookmark fileReferenceURL]);
}
如果我重命名文件,则路径为空。 我看到存储此NSData对象和带有路径的字符串之间没有区别。 所以我很明显地缺少一些东西。
编辑:我也经常会收到这样的错误: CFURLSetTemporaryResourcePropertyForKey failed because it was passed this URL which has no scheme
。
感谢您的帮助,谢谢!
我在代码中找不到任何问题,因此我进行了更改。
在找到“ no scheme”消息的原因之后,我得出结论,该代码需要一些第三方应用程序才能工作,这是不可取的。
我现在正在使用别名。 这是我创建它们的方式:
FSRef fsFile, fsOriginal;
AliasHandle aliasHandle;
NSString * fileOriginalPath = [[filePath absoluteString] stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
OSStatus status = FSPathMakeRef((unsigned char*)[fileOriginalPath cStringUsingEncoding: NSUTF8StringEncoding], &fsOriginal, NULL);
status = FSPathMakeRef((unsigned char*)[fileOriginalPath cStringUsingEncoding: NSUTF8StringEncoding], &fsFile, NULL);
OSErr err = FSNewAlias(&fsOriginal, &fsFile, &aliasHandle);
NSData * aliasData = [NSData dataWithBytes: *aliasHandle length: GetAliasSize(aliasHandle)];
现在,我恢复了这样的路径:
while (object = [rowEnumerator nextObject]) {
NSData * aliasData = [object fileBookmark];
NSUInteger aliasLen = [aliasData length];
if (aliasLen > 0) {
FSRef fsFile, fsOriginal;
AliasHandle aliasHandle;
OSErr err = PtrToHand([aliasData bytes], (Handle*)&aliasHandle, aliasLen);
Boolean changed;
err = FSResolveAlias(&fsOriginal, aliasHandle, &fsFile, &changed);
if (err == noErr) {
char pathC[2*1024];
OSStatus status = FSRefMakePath(&fsFile, (UInt8*) &pathC, sizeof(pathC));
NSAssert(status == 0, @"FSRefMakePath failed");
NSLog(@"%@", [NSString stringWithCString: pathC encoding: NSUTF8StringEncoding]);
} else {
NSLog(@"The file disappeared!");
}
} else {
NSLog(@"CardCollectionUserDefault was zero length");
}
}
但是,我仍然对为什么以前的代码失败感到好奇。 我对此表示感谢。 谢谢!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.