版权声明:本文为博主原创文章,转载请声明出处:http://blog.csdn.net/jinnchang

1、沙盒机制介绍

iOS 中的沙盒机制(SandBox)是一种安全体系。
每个 iOS 应用程序都有一个单独的文件系统(存储空间),而且只能在对应的文件系统中进行操作,此区域被称为沙盒。所有的非代码文件都要保存在此,例如属性文件 plist、文本文件、图像、图标、媒体资源等。

2、沙盒目录结构

通常情况下,每个沙盒包含以下目录及文件:

  • /AppName.app 应用程序的程序包目录。由于应用程序必须经过签名,所以不能在运行时对这个目录中的内容进行修改,否则会导致应用程序无法启动。
  • /Documents/ 保存应用程序的重要数据文件和用户数据文件等。iTunes 同步时会备份该目录。
  • /Library/Caches 保存应用程序使用时产生的支持文件和缓存文件,还有日志文件最好也放在这个目录。iTunes 同步时不会备份该目录。
  • /Library/Preferences 保存应用程序的偏好设置文件(使用 NSUserDefaults 类设置时创建,不应该手动创建)。
  • /tmp/ 保存应用运行时所需要的临时数据,iphone 重启时,会清除该目录下所有文件。

目录结构如下图所示:

补充1:对于上述描述可以这样举例理解,一个记事本应用,用户写的东西需要保存起来,这些东西是用户自行生成的,则需要放在 Documents 目录里。一个新闻应用,如果需要从服务器下载东西展示给用户看,下载的东西就放在 Library/Caches 目录里。苹果审核对这个要求很严格,主要原因是 iCloud 的同步问题。

补充2:如果想知道真机或者模拟器 App 沙盒路径,可通过在项目中执行下述代码打印获取:

  1. NSString *homeDirectoryPath = NSHomeDirectory();

3、获取沙盒中各目录路径

  1. // 获取沙盒根目录路径
  2. NSString *homeDirectoryPath = NSHomeDirectory();
  3. // 获取 Applications 路径
  4. NSString *appDirectoryPath = [NSSearchPathForDirectoriesInDomains(NSApplicationDirectory, NSUserDomainMask, YES) objectAtIndex:0];
  5. // 获取 Documents 路径
  6. NSString *documentDirectoryPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];
  7. // 获取 Caches 路径
  8. NSString *cachesDirectoryPath = [NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES) objectAtIndex:0];
  9. // 获取 tmp 路径
  10. NSString *tmpDirectoryPath = NSTemporaryDirectory();

4、NSFileManager

使用 FileManager 可以对沙盒中的目录、文件进行操作。通过如下方式可以获取 NSFileManager 的单例:

  1. [NSFileManager defaultManager]

5、程序包(NSBundle)

iOS 应用都是通过 bundle 进行封装的,可以狭隘地将 bundle 理解为上述沙盒中的 AppName.app 文件。在 Finder 中,会把 bundle 当做一个文件显示从而防止用户误操作导致程序文件损坏,但其实内部是一个目录,包含了图像、媒体资源、编译好的代码、nib 文件等,这个目录称为 main bundle。

Cocaoa 提供了 NSBundle 类封装了 bundle 操作。

  1. // 获取应用程序的 main bundle
  2. NSBundle *mainBundle = NSBundle.mainBundle;
  3. // 使用 main bundle 获取资源路径
  4. NSString *filePath = [mainBundle pathForResource:@"logo" ofType:@"png"];

6、工具类

FileUtil.h

  1. #import <UIKit/UIKit.h>
  2. @interface FileUtil : NSObject
  3. /**
  4. *  获取 home 路径
  5. *
  6. *  @return
  7. */
  8. + (NSString *)homeDirectoryPath;
  9. /**
  10. *  获取 app 路径
  11. *
  12. *  @return
  13. */
  14. + (NSString *)appDirectoryPath;
  15. /**
  16. *  获取 document 路径
  17. *
  18. *  @return
  19. */
  20. + (NSString *)documentDirectoryPath;
  21. /**
  22. *  获取 caches 路径
  23. *
  24. *  @return
  25. */
  26. + (NSString *)cachesDirectoryPath;
  27. /**
  28. *  获取 tmp 路径
  29. *
  30. *  @return
  31. */
  32. + (NSString *)tmpDirectoryPath;
  33. /**
  34. *  判断目录是否存在
  35. *
  36. *  @param directoryPath 目录路径
  37. *
  38. *  @return
  39. */
  40. + (BOOL)directoryExist:(NSString *)directoryPath;
  41. /**
  42. *  判断文件是否存在
  43. *
  44. *  @param filePath 文件路径
  45. *
  46. *  @return
  47. */
  48. + (BOOL)fileExist:(NSString *)filePath;
  49. /**
  50. *  在父目录下创建子目录
  51. *
  52. *  @param parentDirectoryPath 父目录路径
  53. *  @param directoryName       子目录名称
  54. *
  55. *  @return
  56. */
  57. + (BOOL)createDirectoryAtParentDirectory:(NSString *)parentDirectoryPath directoryName:(NSString *)directoryName;
  58. /**
  59. *  在父目录下创建子文件
  60. *
  61. *  @param parentDirectoryPath 父目录路径
  62. *  @param fileName            子文件名称
  63. *
  64. *  @return
  65. */
  66. + (BOOL)createFileAtParentDirectory:(NSString *)parentDirectoryPath fileName:(NSString *)fileName;
  67. /**
  68. *  删除目录
  69. *
  70. *  @param directoryPath 目录路径
  71. *
  72. *  @return
  73. */
  74. + (BOOL)deleteDirectoryAtPath:(NSString *)directoryPath;
  75. /**
  76. *  删除文件
  77. *
  78. *  @param filePath 文件路径
  79. *
  80. *  @return
  81. */
  82. + (BOOL)deleteFileAtPath:(NSString *)filePath;
  83. /**
  84. *  获取父目录下的子内容(包含目录和文件)
  85. *
  86. *  @param parentDirectoryPath 父目录路径
  87. *
  88. *  @return
  89. */
  90. + (NSArray *)contentsAtParentDirectory:(NSString *)parentDirectoryPath;
  91. /**
  92. *  获取父目录下的所有子目录名称
  93. *
  94. *  @param parentDirectoryPath 父目录路径
  95. *
  96. *  @return
  97. */
  98. + (NSArray *)directoryNamesAtParentDirectory:(NSString *)parentDirectoryPath;
  99. /**
  100. *  获取父目录下的所有子目录路径
  101. *
  102. *  @param parentDirectoryPath 父目录路径
  103. *
  104. *  @return
  105. */
  106. + (NSArray *)directoryPathsAtParentDirectory:(NSString *)parentDirectoryPath;
  107. /**
  108. *  获取父目录下的所有子文件名称
  109. *
  110. *  @param parentDirectoryPath 父目录路径
  111. *
  112. *  @return
  113. */
  114. + (NSArray *)fileNamesAtParentDirectoryPath:(NSString *)parentDirectoryPath;
  115. /**
  116. *  获取父目录下的所有子文件路径
  117. *
  118. *  @param parentDirectoryPath 父目录路径
  119. *
  120. *  @return
  121. */
  122. + (NSArray *)filePathsAtParentDirectoryPath:(NSString *)parentDirectoryPath;
  123. @end

FileUtil.m

  1. #import "FileUtil.h"
  2. @interface FileUtil ()
  3. @end
  4. @implementation FileUtil
  5. + (NSString *)homeDirectoryPath
  6. {
  7. return NSHomeDirectory();
  8. }
  9. + (NSString *)appDirectoryPath
  10. {
  11. NSArray *array = NSSearchPathForDirectoriesInDomains(NSApplicationDirectory, NSUserDomainMask, YES);
  12. return [array objectAtIndex:0];
  13. }
  14. + (NSString *)documentDirectoryPath
  15. {
  16. NSArray *array = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
  17. return [array objectAtIndex:0];
  18. }
  19. + (NSString *)cachesDirectoryPath
  20. {
  21. NSArray *array = NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES);
  22. return [array objectAtIndex:0];
  23. }
  24. + (NSString *)tmpDirectoryPath
  25. {
  26. return NSTemporaryDirectory();
  27. }
  28. + (BOOL)directoryExist:(NSString *)directoryPath
  29. {
  30. NSFileManager *fileManager = [NSFileManager defaultManager];
  31. BOOL isDirectory = NO;
  32. BOOL exist = [fileManager fileExistsAtPath:directoryPath isDirectory:&isDirectory];
  33. if (isDirectory && exist) {
  34. return YES;
  35. }
  36. return NO;
  37. }
  38. + (BOOL)fileExist:(NSString *)filePath
  39. {
  40. NSFileManager *fileManager = [NSFileManager defaultManager];
  41. return [fileManager fileExistsAtPath:filePath];
  42. }
  43. + (BOOL)createDirectoryAtParentDirectory:(NSString *)parentDirectoryPath directoryName:(NSString *)directoryName
  44. {
  45. NSFileManager *fileManager = [NSFileManager defaultManager];
  46. NSString *directoryPath = [NSString stringWithFormat:@"%@/%@", parentDirectoryPath, directoryName];
  47. return [fileManager createDirectoryAtPath:directoryPath withIntermediateDirectories:YES attributes:nil error:nil];
  48. }
  49. + (BOOL)createFileAtParentDirectory:(NSString *)parentDirectoryPath fileName:(NSString *)fileName
  50. {
  51. NSFileManager *fileManager = [NSFileManager defaultManager];
  52. NSString *filePath = [NSString stringWithFormat:@"%@/%@", parentDirectoryPath, fileName];
  53. return [fileManager createFileAtPath:filePath contents:nil attributes:nil];
  54. }
  55. + (BOOL)deleteDirectoryAtPath:(NSString *)directoryPath
  56. {
  57. NSFileManager *fileManager = [NSFileManager defaultManager];
  58. if ([self directoryExist:directoryPath]) {
  59. return [fileManager removeItemAtPath:directoryPath error:nil];
  60. }
  61. return NO;
  62. }
  63. + (BOOL)deleteFileAtPath:(NSString *)filePath
  64. {
  65. NSFileManager *fileManager = [NSFileManager defaultManager];
  66. if ([self fileExist:filePath]) {
  67. return [fileManager removeItemAtPath:filePath error:nil];
  68. }
  69. return NO;
  70. }
  71. + (NSArray *)contentsAtParentDirectory:(NSString *)parentDirectoryPath
  72. {
  73. NSFileManager *fileManager = [NSFileManager defaultManager];
  74. return [fileManager contentsOfDirectoryAtPath:parentDirectoryPath error:nil];
  75. }
  76. + (NSArray *)directoryNamesAtParentDirectory:(NSString *)parentDirectoryPath
  77. {
  78. NSFileManager *fileManager = [NSFileManager defaultManager];
  79. BOOL isDirectory = NO;
  80. NSMutableArray *directoryPaths = [[NSMutableArray alloc] init];
  81. for (NSString *content in [self contentsAtParentDirectory:parentDirectoryPath]) {
  82. NSString *path = [NSString stringWithFormat:@"%@/%@", parentDirectoryPath, content];
  83. if ([fileManager fileExistsAtPath:path isDirectory:&isDirectory]) {
  84. if (isDirectory) {
  85. [directoryPaths addObject:content];
  86. }
  87. }
  88. }
  89. return [directoryPaths copy];
  90. }
  91. + (NSArray *)directoryPathsAtParentDirectory:(NSString *)parentDirectoryPath
  92. {
  93. NSFileManager *fileManager = [NSFileManager defaultManager];
  94. BOOL isDirectory = NO;
  95. NSMutableArray *directoryPaths = [[NSMutableArray alloc] init];
  96. for (NSString *content in [self contentsAtParentDirectory:parentDirectoryPath]) {
  97. NSString *path = [NSString stringWithFormat:@"%@/%@", parentDirectoryPath, content];
  98. if ([fileManager fileExistsAtPath:path isDirectory:&isDirectory]) {
  99. if (isDirectory) {
  100. [directoryPaths addObject:path];
  101. }
  102. }
  103. }
  104. return [directoryPaths copy];
  105. }
  106. + (NSArray *)fileNamesAtParentDirectoryPath:(NSString *)parentDirectoryPath
  107. {
  108. NSFileManager *fileManager = [NSFileManager defaultManager];
  109. BOOL isDirectory = NO;
  110. NSMutableArray *filePaths = [[NSMutableArray alloc] init];
  111. for (NSString *content in [self contentsAtParentDirectory:parentDirectoryPath]) {
  112. NSString *path = [NSString stringWithFormat:@"%@/%@", parentDirectoryPath, content];
  113. if ([fileManager fileExistsAtPath:path isDirectory:&isDirectory]) {
  114. if (!isDirectory) {
  115. [filePaths addObject:content];
  116. }
  117. }
  118. }
  119. return [filePaths copy];
  120. }
  121. + (NSArray *)filePathsAtParentDirectoryPath:(NSString *)parentDirectoryPath
  122. {
  123. NSFileManager *fileManager = [NSFileManager defaultManager];
  124. BOOL isDirectory = NO;
  125. NSMutableArray *filePaths = [[NSMutableArray alloc] init];
  126. for (NSString *content in [self contentsAtParentDirectory:parentDirectoryPath]) {
  127. NSString *path = [NSString stringWithFormat:@"%@/%@", parentDirectoryPath, content];
  128. if ([fileManager fileExistsAtPath:path isDirectory:&isDirectory]) {
  129. if (!isDirectory) {
  130. [filePaths addObject:path];
  131. }
  132. }
  133. }
  134. return [filePaths copy];
  135. }
  136. @end

7、结语

参考资料如下:

About Files and Directories

NSFileManager Class Reference

NSBundle Class Reference

 
 

iOS 文件操作:沙盒(SandBox)、文件操作(FileManager)、程序包(NSBundle)的更多相关文章

  1. 沙盒SandBox

    每个App都有自己的沙盒,也就是一个存储空间.App之间没有权限访问对方的沙盒资源.沙盒的目录下有三个文件夹:Documents.Library.temp 目录结构 Documents:用于存储用户数 ...

  2. IOS 学习之 iOS沙盒(sandbox) 介绍 沙盒机制 文件操作(一)

    1.iOS沙盒机制 iOS应用程序只能在为该改程序创建的文件系统中读取文件,不可以去其它地方访问,此区域被成为沙盒,所以所有的非代码文件都要保存在此,例如图像,图标,声音,映像,属性列表,文本文件等. ...

  3. iOS 沙盒(sandbox)机制和文件操作

    本文参看了 http://www.uml.org.cn/mobiledev/201209211.asp#1 这篇文章中的介绍,尊重原著. 1.IOS沙盒机制 IOS应用程序只能在本应用程序中创建的文件 ...

  4. IOS学习之IOS沙盒(sandbox)机制和文件操作

    IOS学习之IOS沙盒(sandbox)机制和文件操作(一) 1.IOS沙盒机制 IOS应用程序只能在为该改程序创建的文件系统中读取文件,不可以去其它地方访问,此区域被成为沙盒,所以所有的非代码文件都 ...

  5. iOS学习之iOS沙盒(sandbox)机制和文件操作(一)

    1.iOS沙盒机制 iOS应用程序仅仅能在为该改程序创建的文件系统中读取文件,不能够去其他地方訪问,此区域被成为沙盒,所以全部的非代码文件都要保存在此,比如图像,图标,声音,映像,属性列表,文本文件等 ...

  6. iOS学习之iOS沙盒(sandbox)机制和文件操作复习

    1.iOS沙盒机制 iOS应用程序只能在为该改程序创建的文件系统中读取文件,不可以去其它地方访问,此区域被成为沙盒,所以所有的非代码文件都要保存在此,例如图像,图标,声音,映像,属性列表,文本文件等. ...

  7. iOS学习之iOS沙盒(sandbox)机制和文件操作1

    iOS学习之iOS沙盒(sandbox)机制和文件操作 接上篇 iOS学习之iOS沙盒(sandbox)机制和文件操作(一) 我们看看如何获取应用程序沙盒目录.包括真机的沙盒的目录. 1.获取程序的H ...

  8. IOS沙盒(sandbox)机制和文件操作

    IOS学习之IOS沙盒(sandbox)机制和文件操作   作者:totogo2010 ,发布于2012-9-21,来源:CSDN   目录: IOS学习之IOS沙盒(sandbox)机制和文件操作( ...

  9. 查看iOS沙盒(SanBox)文件

    转载:http://www.2cto.com/kf/201211/169212.html 每一个iOS程序都一个自己的文件系统,这个文件系统叫应用程序沙盒(SanBox),它存放这代码以外的文件,其他 ...

  10. iOS开发之--沙盒的操作

    iphone沙箱模型的有四个文件夹,分别是什么,永久数据存储一般放在什么位置,得到模拟器的路径的简单方式是什么. documents,tmp,app,Library. (NSHomeDirectory ...

随机推荐

  1. Java调用R——rJava的安装和配置

    rJava是Java通过JRI调用R所要安装的包.配置起来比较麻烦,我参考网上进行配置,使用rJava包中example里面的示例测试,控制台显示: Cannot find JRI native li ...

  2. Java Socket编程 标准范例(多线程)

    链接地址:http://blog.csdn.net/benweizhu/article/details/6615542 服务器端(Server)非多线程 package com.zeph.server ...

  3. BZOJ 2440 完全平方数(莫比乌斯反演+二分查找)

    题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=23362 题意:定义含有平方数因子的数为完全平方数(平方数因子不包含 ...

  4. 多线程笔记--原子操作Interlocked系列函数

    前面写了一个多线程报数的功能,为了描述方便和代码简洁起见,只输出最后的报数结果来观察程序运行结果.这非常类似一个网站的客户访问统计,每个用户登录用一个线程模拟,线程运行时将一个表示计数的变量递增.程序 ...

  5. HDU2018-母牛的故事

    描述: 有一头母牛,它每年年初生一头小母牛.每头小母牛从第四个年头开始,每年年初也生一头小母牛.请编程实现在第n年的时候,共有多少头母牛? 代码: 第n年的牛,等于第n-1年的牛(已有的)+第n-3年 ...

  6. iOS自动自动隐藏软键盘

    自动隐藏软键盘,分为两步,一个是单击软键盘外部任意空间:另外一个是单击软键盘上的return键.下面依次实现 单击软键盘外部空间键隐藏软键盘: 一:在viewDidLoad中添加一个UITabGest ...

  7. POJ 1151Atlantis 扫描线+线段树求矩形面积并

    题目链接 #include <iostream> #include <vector> #include <cstdio> #include <cstring& ...

  8. 25_Downloading An Image

    一个App,从网上下载一张图片(给出图片地址),重新命名,然后保存到手机中,再从手机中取出显示在屏幕上. 难度不大,就是找图片很蛋疼,百度搜索出来的过一会儿会失效,Google搜索出来的有些需要FQ, ...

  9. 从51跳新唐cortex-m0学习1——思想转变

    Cortex-M0学习第一帖 序言:这里先说一下,大家在看帖子时候,可能看见字数比较多的,可能只是先大概浏览一下,之后从中挑几段大概瞅瞅,但是我要说,如果你碰到一个适合的帖子,请仔细品读,这是我在论坛 ...

  10. Objective-c Category(类别)

    category是Objective-c里面最常用的功能之一. category可以为已经存在的类增加方法,而不需要增加一个子类. 类别接口的标准语法格式如下: #import "类名.h& ...