IOS5多了一个比较重要的功能iCloud,但是同时也出现一个问题,很多的APP都把很大量的数据存在APP底下的Documents(/Documents
)文件夹里面,这样苹果会reject掉你的APP的,除非你不再更新就一直把APP摆在APPStore,显然这样是不可行的,因为你这些文件会同步到iCloud上面的。
这里有办法不让苹果reject你的APP,一个就是把这些文件存在Caches
(/Library/Caches
)文件夹里面,但是这个苹果说了,如果在低存储空间的时候会清理的,所以你有可能就这样被清了这些数据,会导致一些列的问题,如果你不在意这些文件是否会被删除,或者这些数据只要保存那么几天,那么这样就行了
如果你要文件不删除但是也不备份,可以使用下面代码来做标记,不做备份处理
1 - (BOOL)addSkipBackupAttributeToItemAtURL:(NSURL *)URL 2 { 3 assert([[NSFileManager defaultManager] fileExistsAtPath: [URL path]]); 4 NSError *error = nil; 5 BOOL success = [URL setResourceValue: [NSNumber numberWithBool: YES] 6 forKey: NSURLIsExcludedFromBackupKey error: &error]; 7 if(!success){ 8 NSLog(@"Error excluding %@ from backup %@", [URL lastPathComponent], error); 9 } 10 return success; 11 }
1 #import <sys/xattr.h> 2 - (BOOL)addSkipBackupAttributeToItemAtURL:(NSString*) path 3 { 4 if (SYSTEM_VERSION_LESS_THAN(@"5.1")) 5 { 6 constchar* folderPath = [pathfileSystemRepresentation]; 7 const char* attrName ="com.apple.MobileBackup"; 8 u_int8_t attrValue = 1; 9 intresult = setxattr(folderPath, attrName,&attrValue,sizeof(attrValue),0,0); 10 return result == 0; 11 } 12 else 13 { 14 #ifndef __IPHONE_5_1 15 #define NSURLIsExcludedFromBackupKey @"NSURLIsExcludedFromBackupKey" 16 #endif 17 NSError *error = nil; 18 NSURL* url = [NSURLfileURLWithPath:path]; 19 BOOLsuccess = [url setResourceValue:[NSNumbernumberWithBool:YES] 20 forKey:NSURLIsExcludedFromBackupKey 21 error: &error]; 22 return success; 23 } 24 }
iOS应用在运行时经常要创建一些文件,不过这些文件要如何存放呢?有没有什么要求呢?
由于手机资源空间有限而且考虑到Apple推出的iCloud,我们确实要对创建出的文件按照作用的不同,分出几种类别出来,并设置文件备份属性attribute(需iOS5.0.1及以上),从而让iOS系统更好地管理和对待我们所创建的文件。
iOS的文件分类、存放路径及文件属性
iOS Data Storage Guidelines 和 “do not back up”文件属性
iOS
5有了iCloud后,Apple更新了数据存储指导方针,以适应于iCloud存储,同时增加了“不要备份”文件属性,可以指定文件不备份和上传到iCloud
摘录如下,供大家参考:
iOS 数据存储指导方针
iCloud包括了备份,会通过Wi-Fi每天自动备份用户iOS设备。app的home目录下的所有东西都会被备份,除了应用Bundle本身、缓存目录和temp目录。已购买的音乐、应用、书籍、Camera
Roll、设备设置、主屏幕、App组织、消息、铃声也都会被备份。由于备份通过无线进行,并且为每个用户存储在iCloud中,应用需最小化自己存储的数据数量。大文件会延长备份时间,并且消耗用户的可用iCloud空间。
为了确保备份尽可能快速高效,应用存储数据需要遵循以下指导方针:
1.
只有那些用户生成的文档或其它数据,或者应用不能重新创建的数据,才应该存储在/Documents目录下,并且会被自动备份到iCloud。
2.
可以重新下载或生成的数据,应该存储在/Library/Caches目录。例如数据库缓存文件、可下载文件(杂志、报纸、地图应用使用的数据)等都属于这一类。
3.
临时使用的数据应该存放在/tmp目录。尽管这些文件不会被iCloud备份,应用在使用完之后需要记得删除这些文件,这样才不会继续占用用户设备的空间。
4.
使用”不要备份”属性来指定那些需要保留在设备中的文件(即使是低存储空间情况下)。那些能够重新生成,但在低存储空间时仍需保留,对应用正常运行有影
响,或者用户希望文件在离线时可用的文件,需要使用这个属性。无论哪个目录下的文件(包括Documents目录),都可以使用这个属性。这些文件不会被
删除,也不会包含在用户的iCloud或iTunes备份中。由于这些文件一直占用着用户设备的存储空间,应用有责任定期监控和删除这些文件。
iOS 5.0.1开始支持”do not back
up”文件属性,允许开发者明确地指定哪些文件应该被备份,哪些是本地缓存可以自动删除,哪些文件不需要备份但不能删除。此外,对目录设置这个属性,会阻止备份该目录和目录中的所有内容。
注意”do not back up”属性只能用于iOS
5.0.1以后版本。之前版本的应用需要存储数据到/Library/Caches目录才能避免被备份。由于老的系统忽略这个属性,你需要确保应用在所有iOS版本中,都遵循上面的iOS
Data Storage Guidelines。
关键数据
内容:用户创建的数据文件,无法在删除后自动重新创建,且会
路径:主目录/Documents
属性:不要设置"不备份"
管理:iOS系统即时遇到存储空间不足的情况下,也不会清除,同时会备份到iTunes或iCloud中
缓存数据
内容:可用于离线环境,可被重复下载重复生成,即时在离线时缺失,应用本身也可以正常运行
路径:主目录/Library/Caches
属性:默认
管理:在存储空间不足的情况下,会清空, 并且不会被自动备份到iTunes和iCloud中
读取Cache目录
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES); NSString *path = [paths objectAtIndex:0]; NSLog(@"%@", path);
临时数据
内容:应用运行时,为完成某个内部操作临时生成的文件
路径:主目录/tmp
属性:默认
管理:随时可能被iOS系统清除,且不会自动备份到iTunes和iCloud,尽管 iCloud 不会备份这些文件,但在应用在使用完这些数据之后要注意随时删除,避免占用用户设备的空间
NSString *tmpDir = NSTemporaryDirectory(); NSLog(@"%@", tmpDir);
离线数据
内容:与缓存数据类似,可以被重新下载和重建,但是用户往往希望在离线时数据依然能够托托地存在着
目录:主目录/Documents 或 主目录/Library/自定义的文件夹
属性:放于Documents下不需设置,放在自定义文件夹中需设置"不备份"
管理:与关键数据类似,即时在存储空间不足的情况下也不会清楚,应用自己应该清除已经不再使用的文件,以免浪费用户设备空间
项目自带的.bundle资源束
项目自带的资源存放在.bundle中这些资源只读不能写
NSString *defaultDBPath = [[NSBundlemainBundle] resourcePath];
读取Library目录
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSLibraryDirectory, NSUserDomainMask, YES); NSString *path = [paths objectAtIndex:0]; NSLog(@"%@", path);