转载

iOS11文件存储最佳实践

本文是来自@FlyOceanFish的投稿

众所周知,iOS11之前的版本我们无法看到应用里边的任何文件,这主要是由于iOS的沙盒机制导致的。在我们应用的沙盒里边,有三个文件夹供我们使用来存储文件。分别是DocumentsLibrarytmp

  • Documents 您应该将所有的应用程序数据文件写入到这个目录下。这个目录用于存储用户数据。该路径可通过配置实现iTunes共享文件。可被iTunes备份。

  • Library Preferences 目录:包含应用程序的偏好设置文件。您不应该直接创建偏好设置文件,而是应该使用NSUserDefaults类来取得和设置应用程序的偏好. Caches 目录:用于存放应用程序专用的支持文件,保存应用程序再次启动过程中需要的信息。 可创建子文件夹。可以用来放置您希望被备份但不希望被用户看到的数据。该路径下的文件夹,除Caches以外,都会被iTunes备份。

  • tmp 这个目录用于存放临时文件,保存应用程序再次启动过程中不需要的信息。该路径下的文件不会被iTunes备份。

不过由于iOS11系统中增加了一个Files的应用,导致DocumentsLibrary有些细微的变化。

Files 是什么

Files 可以集中管理iOS上应用内创建的文件,以及各个云盘服务中保存的文件。

Files使用

Files会自动整合应用内公开的所有文件,其实就是Documents文件夹中所有的文件。但是有时候我们存储的用户的数据不想让用户看到,这时应该怎么办呢?这时候我们可以将数据存储到ApplicationSupport文件夹。这个文件夹与Documents基本一样,除了一个能被用户看到,一个是隐藏的。

实践

我们新建一个工程,然后在Info.plist中增加Application supports iTunes file sharing和Supports opening documents in place这两个选项,并且设置为YES

iOS11文件存储最佳实践

Application supports iTunes file sharing 可以通过iTunes操作手机上APP的Documents中的内容,实现了文件的共享

加上了这两个值之后,此时应用的Documents文件夹中的内容就可以通过Files应用看到了。

iOS11文件存储最佳实践
iOS11文件存储最佳实践

设置Documents或Library文件夹下的文件不被备份至iCloud

- (BOOL)addSkipBackupAttributeToItemAtURL:(NSURL *)URL {     assert([[NSFileManager defaultManager] fileExistsAtPath: [URL path]]);     NSError *error = nil;     BOOL success = [URL setResourceValue:[NSNumber numberWithBool: YES]                                   forKey: NSURLIsExcludedFromBackupKey error: &error];     if(!success){         NSLog(@"Error excluding %@ from backup %@", [URL lastPathComponent], error);     }     return success; }

检查可用空间大小

主要用于当我们下载某个文件到手机的时候,如果此时手机的存储空间不够用,可以先提示用户。否则不会下载,增加用户的体验

NSURL *fileURL = [[NSURL alloc] initFileURLWithPath:NSTemporaryDirectory()]; NSError *error = nil; NSDictionary *results = [fileURL resourceValuesForKeys:@[NSURLVolumeAvailableCapacityForImportantUsageKey] error:&error]; if (!results) {     NSLog(@"Error retrieving resource keys: %@
%@", [error localizedDescription], [error userInfo]);     abort(); } NSLog(@"Available capacity for important usage: %@", results);
  • NSURLVolumeAvailableCapacityKey 获取到整个手机剩余的可用空间

  • NSURLVolumeTotalCapacityKey 获取到整个手机的存储空间,比如32G的手机获取的数据时32G

  • NSURLVolumeAvailableCapacityForImportantUsageKey和NSURLVolumeAvailableCapacityForOpportunisticUsageKey 第一个获取的空间比第二个获取到的大。具体怎么计算的不知道,NSURLVolumeAvailableCapacityForImportantUsageKey与NSURLVolumeAvailableCapacityKey获取的值比较接近;NSURLVolumeAvailableCapacityForOpportunisticUsageKey获取到的值比NSURLVolumeAvailableCapacityKey小一些。作者猜想可能这几个枚举与沙河里边的文件夹相对应吧。(如果有知道具体怎么回事的可以留言哦)

我的博客

FlyOceanFish


正文到此结束
Loading...