iOS开发之沙盒(sandbox)机制

原创 2016年05月30日 10:43:42

1、iOS沙盒机制

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

 1.1、每个应用程序都有自己的存储空间
 1.2、应用程序不能翻过自己的围墙去访问别的存储空间的内容
 1.3、应用程序请求的数据都要通过权限检测,假如不符合条件的话,不会被放行。
     通过这张图只能从表层上理解sandbox是一种安全体系,应用程序的所有操作都要通过这个体系来执行,其中核心内容是:sandbox对应用程序执行各种操作的权限限制。




2、打开模拟器沙盒目录

下面看看模拟器的沙盒文件夹在mac电脑上的什么位置。

文件都在个人用户名文件夹下的一个隐藏文件夹里,中文叫资源库,他的目录其实是Library。

2.1 方法1、可以设置显示隐藏文件,然后在Finder下直接打开。设置查看隐藏文件的方法如下:打开终端,输入命名

显示Mac隐藏文件的命令: defaults write com.apple.finder AppleShowAllFiles -bool true

隐藏Mac隐藏文件的命令: defaults write com.apple.finder AppleShowAllFiles -bool false

输完单击Enter键 退出终端 重新启动Finder就可以了

重启Finder: 鼠标单击窗口左上角的苹果标志-->强制退出-->Finder-->重新启动

现在能看到资源库文件夹了。

打开资源库后找到/Application Support/iPhone Simulator/文件夹。这里面就是模拟器的各个程序的沙盒目录了。


2.2 方法2、这种方法更方便,在Finder上点->前往->前往文件夹,输入/Users/username/Library/Application Support/iPhone Simulator/  前往。

username这里写你的用户名。

3、目录结构

默认情况下,每个沙盒含有3个文件夹:Documents, Library 和 tmp。因为应用的沙盒机制,应用只能在几个目录下读写文件
Documents:苹果建议将程序中建立的或在程序中浏览到的文件数据保存在该目录下,iTunes备份和恢复的时候会包括此目录
Library:存储程序的默认设置或其它状态信息;

Library/Caches:存放缓存文件,iTunes不会备份此目录,此目录下文件不会在应用退出删除

tmp:提供一个即时创建临时文件的地方。


iTunes在与iPhone同步时,备份所有的Documents和Library文件。

iPhone在重启时,会丢弃所有的tmp文件。


我们创建一个IosSandbox的项目来展开沙盒和文件读写等操作的练习。

创建后找到模拟器上对应的目录,

这是目录全展开了。

  

这是上面提到的三个目录 :Documents、Library、 tmp


  //doucuments 文件路径

    NSString *doucumentsPath =  [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES)firstObject];

   NSLog(@"%@",doucumentsPath);

    

    //获取包路径

   NSString *appPath = [[NSBundlemainBundle]resourcePath];

   NSLog(@"%@",appPath);

    

   /*

     沙盒: 其实对于每一个应用程序,都有唯一的一个本地文件与之对应,名字由系统随机生成,这个文件就是沙盒

     沙盒机制:沙盒机制其实就是对每一个应用程序的资源起到一个保护作用,当前程序不允许访问其他程序的资源,其他程序也不允许访问当前程序的资源

     

     对于每一个应用程序的沙盒文件中都包含以下文件:

     1.documents : 用来存储持久化数据文件.如果我们想对一个文件进行长久存储,就放在该文件夹下

     2.Library:

       (a).Caches: 缓存文件,存放已经下载完成的视频,音频,图片等等.一般我们会在该文件下创建 Images,Videoes等文件分别存放图片,视频,音频

       (b)Preferences: 用于存储用户偏好设置,比如用于判别程序是否第一次启动的plist文件就放在该文件夹下

     3.tmp: 存放未下载完成的视频,音频等.一般我们会将下载完成的视频,音频再手动移动到Caches

     XXX.app : 应用程序的包,应用程序的资源都来源于包,而包也是我们上传到appStore以及用户从appStore下载的文件对于包内的资源我们不能进行修改,更不能删除

     

     另外,对于以上文件都是由系统创建,不允许随意删除修改,我们只能删除修改自己创建的文件

     

     */


版权声明:本文为博主原创文章,未经博主允许不得转载。

IOS开发中的沙盒机制

iOS App都有自己的存储空间,这个存储空间就叫沙盒,app可以在自己的沙河文件中读取文件,但是呢却不能访问其他app的沙盒文件,每个app的信息都是独立的,app之间不能进行信息通信,但是唯独可通...
  • qiaoqiaoqiao2014
  • qiaoqiaoqiao2014
  • 2015年07月24日 14:19
  • 446

【iOS知识学习】_iOS沙盒机制

IOS中的沙盒机制(SandBox)是一种安全体系,它规定了应用程序只能在为该应用创建的文件夹内读取文件,不可以访问其他地方的内容。所有的非代码文件都保存在这个地方,比如图片、声音、属性列表和文本文件...
  • weasleyqi
  • weasleyqi
  • 2014年06月16日 23:56
  • 3616

iOS-沙盒机制-整合篇

前言:突然想学习一下,沙盒,看了那么多博客,我四处的搜集一下总结一下,为了以后方便学习,留存一篇整合的文章。 一、沙盒机制 1.简介: --概念:每个iOS应用都...
  • qq_33701006
  • qq_33701006
  • 2016年07月08日 01:05
  • 822

【计算机】基本概念的理解 —— 沙盒(sandbox)、交互式计算/编程/应用

1. 沙盒(sandbox)沙盒是在受限的安全环境中运行应用程序的一种做法,这种做法是要限制授予应用程序的代码访问权限:...
  • lanchunhui
  • lanchunhui
  • 2017年04月17日 17:12
  • 737

iOS 安全模型浅析(二) ---- 沙盒机制

苹果的沙盒机制想必大家都听过,并且都会称赞这是iOS做的比安卓系统好的一个重要因素,沙盒机制让iOS更为安全。 沙盒机制历史上被称作安全带,是一种基于FreeBSD系统(是一种类UNIX操作系统,是由...
  • youshaoduo
  • youshaoduo
  • 2017年03月26日 20:40
  • 4431

iOS--在Sandbox(沙盒)中创建文件夹和文件

本文Demo源代码:https://github.com/gaussli/FileManagerDemo 之前了解过了沙盒内部的基本组成,今天学习下在沙盒中创建文件夹以及文件 之前在学习沙盒的时候...
  • gauss_li
  • gauss_li
  • 2014年12月22日 23:30
  • 2265

iOS沙盒操作最全讲解

iOS学习笔记(十七)——文件操作(NSFileManager) 分类: iOS开发 目录(?)[+]        iOS的沙盒机制,应用只能访问自己应...
  • mySwift
  • mySwift
  • 2015年06月01日 00:20
  • 556

详解iOS应用程序内使用IAP/StoreKit付费、沙盒(SandBox)测试、创建测试账号流程!

转自:http://blog.csdn.net/xiaominghimi/article/details/6937097 参考:http://mobile.51cto.com/hot-410094_a...
  • azhou_hui
  • azhou_hui
  • 2015年04月20日 19:32
  • 7755

iOS开发 如何查看真机里的沙盒文件

Xcode当前处于真机调试状态,
  • jingfa1993
  • jingfa1993
  • 2016年12月16日 18:00
  • 616

iOS开发总结之沙盒存储

1.属性列表plist存储 plist只能存储 是写入到Documents目录下 且只能存储系统自带的一些常规的类, 也就是有writeToFile方法的对象才可以使用plist保存...
  • sunnyboy9
  • sunnyboy9
  • 2016年04月24日 22:18
  • 7555
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:iOS开发之沙盒(sandbox)机制
举报原因:
原因补充:

(最多只允许输入30个字)