iOS 应用沙盒以及应用数据的存储方式

一、应用沙盒

  • 1、概念:

  • 每个iOS应用都有自己的应用沙盒(应用沙盒就是应用的文件夹)。与其他应用系统隔离,应用必须待在自己的沙盒里,其他应用不能访问该沙盒。

  • 2、 如何去访问iOS应用的沙盒?

执行这个语句,可以打印应用沙盒的路径:NSString *str = NSHomeDirectory();
​ NSLog(@“沙盒路径:%@”,str);
可以发现每次打印的沙盒路径都是变化的,但是访问的还是同一个应用的沙盒路径。

  • 3、可以发现访问的应用沙盒的系统文件目录。假设应用的名称叫Layer。有Documents、Library、SystemData、temp
  • 4、 那么这四个文件夹的区别是什么呢?
  • 1> 应用程序包:(上图中的Layer),包含了所有的资源文件和可执行文件。
  • 2> Documents:保存应用运行时生成的需要持久化的数据,iTunes 同步设备时就备份该目录。例如:游戏应用可将游戏存档保存在该目录。
  • 3> tmp:保存应用运行时所需的临时数据,使用完毕后再将相应的文件从该目录删除。应用没有运行时,系统也可能会清除该目录下的文件。iTunes 同步设备时不会备份该目录。
  • 4> Library / Caches:保存应用运行时生成的需要持久化的数据,ITunes 同步设备时不会备份该目录。一般存储体积大、不需要备份的非重要数据。
  • 5> Library / Preference:保存应用的所有偏好设置。iOS 的setting(设置)应用会在该目录中查找应用的设置信息。iTunes 同步设备时会备份该目录。

二、iOS应用数据存储的常用方式

  • XML属性列表(plist文件)
  • Preference(偏好设置)
  • NSKeyArchiver归档
  • SQLite3
  • Core Data

1、什么数据能够做 plist 存储?

  • 数组、字典和字符串有 writeToFile:这个方法,可以存储 plist文件中的数据。
  • 字符串虽然能够做 plist 存储,但是 plist 本身不支持字符串
    2、获取沙盒中的文件路径
//这里写了一个宏,表示文件中全局可用,访问到的是文件名为 contacts.data 这个文件。
#define kFilePath [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)[0] stringByAppendingPathComponent:@"contacts.data"]
// NSUserDomainMask 代表从用户文件夹下找
// YES 代表展开路径中的波浪字符~

注意: 路径必须展开(搜索路径的时候,第三个参数一定是 YES),如果为 NO 的话,系统会将应用的沙盒路径替换成波浪号~

2、偏好设置

  • 不需要关心文件名
  • 快速做键值对的存储
  • 底层使用的 NSUserDefaults 来实现数据的存储
// 使用 NSUserDefaults 来保存开关的状态
NSUserDefaults *userDefaults = [NSUserDefaults standardUserDefaults];
[userDefaults setObject:self.remindPwdSwich.isOn ? @"Y" : @"N" forKey:@"remindOn"];
[userDefaults setObject:self.autoLoginSwich.isOn ? @"Y" : @"N" forKey:@"autoLoginOn"];
[userDefaults setObject:self.userNameTF.text forKey:@"userName"];
[userDefaults setObject:self.passwordTF.text forKey:@"password"];          
[userDefaults synchronize];  //立即写入

3、归档、解档

  • 如果存储自定义对象,一定要用解、归档的操作。
  • plist、偏好设置都不好使。
  • 自定义对象解、归档的时候一定要遵守协议
  • 解析文件就会调用 initWithCoder:方法。
  • 在解档属性的时候,一定要为属性 赋值。
    在这里插入图片描述
    在这里插入图片描述
//归档联系人信息
 NSString *filePath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)[0] stringByAppendingPathComponent:@"contacts.data"];
   NSError *error = nil;
   NSData *data = [NSKeyedArchiver archivedDataWithRootObject:self.contacts requiringSecureCoding:YES error:&error];
    if (error) {
        NSLog(@"归档失败,失败的原因是:%@",error);
    } else {
      BOOL success = [data writeToFile:filePath atomically:YES];
        if (success) {
            NSLog(@"写入成功");
        } else {
            NSLog(@"写入失败");
        }
    }
//解档
 NSError *error = nil;
 NSData *data = [NSData dataWithContentsOfFile:filePath];
 self.contacts = [NSKeyedUnarchiver unarchivedObjectOfClass:[Contact class] fromData:data error:&error];
 if (!error) {
     NSLog(@"解档成功");
} else {
     NSLog(@"解档失败");
}

3、SQLite3

  • SQLite3只是一个轻型的嵌入式数据库引擎,占用资源非常低,处理速度比Mysql还快,专门用于移动设备上进行适量的数据存取,它只是一个文件,不需要服务器进程。
    4、Core Data
  • Core Data是iOS5之后才出现的一个框架,提供了直接使用SQLite数据库的大部分灵活性,它提供了对象-关系映射(ORM)的功能,即能够将OC对象转化成数据,保存在SQLite数据库文件中,也能够将保存在数据库中的数据还原成OC对象,通过CoreData管理应用程序的数据模型,可以极大程度减少需要编写的代码数量。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
iOS和安卓的沙盒是用来保护应用程序数据的安全性的一种机制。它们的主要区别如下: 1. 安全性:iOS沙盒机制相对安卓更加严格。iOS要求应用程序在自己的沙盒内运行,限制了应用之间的直接访问和交互。而安卓的沙盒机制相对较弱,应用程序可以更容易地访问和共享数据。 2. 文件系统结构:iOS沙盒机制将每个应用程序的文件分隔为多个目录,包括应用程序包、文档目录、缓存目录等。每个目录只能由特定的应用程序进行访问和写入。而安卓的沙盒机制通常是基于应用的用户ID,并且应用程序可以自由地向沙盒中的文件系统写入和访问。 3. 权限管理:iOS沙盒机制通过权限管理来限制应用程序对系统资源的访问。应用程序需要在安装时声明所需的访问权限,并由用户在使用时授予。而安卓的沙盒机制在应用程序安装时会一次性获取所有权限,并且用户只能在软件设置中进行修改。 4. 应用程序的更新:iOS沙盒机制要求每个应用程序都在单独的容器中运行,因此应用程序的更新通常是通过替换整个应用程序包来完成的。而安卓的沙盒机制允许应用程序在更新时只替换其中的部分文件,从而减少下载和更新时间。 综上所述,iOS和安卓的沙盒机制在安全性、文件系统结构、权限管理和应用程序更新方面存在一些差异。iOS沙盒机制相对更严格,保护了应用程序和用户数据的安全性,但也可能限制了应用程序之间的交互。而安卓的沙盒机制相对较弱,允许应用程序更自由地访问和共享数据,但也可能增加了安全隐患。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值