浅谈iOS开发中的对象归档

        iOS提供的数据持久化方式有:SQLiteCoreData属性列表、NSUserDefault对象归档。

        这里来简单介绍下iOS开发中的对象归档:

        对象归档是将对象归档以文件的形式保存到磁盘中(也称为序列化,持久化)使用的时候读取该文件的保存路径读取文件的内容(也称为接档,反序列化)

        对象归档的文件是保密的磁盘上无法查看文件中的内容,而属性列表是明文的可以查看)

        对象归档有两种方式:1、对foundat中对象进行归档     2、自定义对象归档


        1、简单对象归档

 

       使用两个类:NSKeyedA richivNSKeyedUnarchiver

 

       NSStr*homeDirectori=NSHomeDirectori;  //获取根目录

 

       NSStringhomePath=[homeDirectoristringByA ppendingPathComponent:@"自定义文件名,如test.archiver"];

 

       NSA rrai*arrai=@[@"abc",@"123",@12];

 

       Boolflag=[NSKeyedA richivarchiveRootObject:arraitoFile:homePath];

 

      ifflag{

 

      NSLog@"归档成功!";

 

      }

 

      读取归档文件的内容:

 

      NSA rrai*arrai=[NSKeyedUnarchivunarchiveObjectWithFile:homePath];

 

      NSLog@"%@",arrai;

 

        这样就简单了实现了将NSA rrai对象的归档和解档。

 

       但是这种归档方式有个缺点,就是一个文件只能保存一个对象,如果有多个对象要保存的话那岂不是有n多个文件,这样不是很适合的所以有了下面这种归档方式。

 

        2、自定义内容归档

       归档:

       使用NSData实例作为归档的存储数据

       添加归档的内容---使用键值对

       完成归档

       解归档:

       从磁盘读取文件,生成NSData实例

       根据NSData实例和初始化解归档实例

       解归档,根据kei访问value

 

       NSStr*homeDirectori=NSHomeDirectori;//获取根目录

 

       NSStringhomePath=[homeDirectoristringByA ppendingPathComponent:@"自定义文件名,如test.archiver"];

 

       NSMutableData*data=[[NSMutableDataalloc]init];

 

       NSKeyedA rchiv*archiv=[[NSKeyedA rchivalloc]initForWritingWithMutableData:data];

 

       [archivencodeFloat:50forKey:@"age"];

 

       [archivencodeObject:@"jack"forKey:@"name"];

 

       [archivfinishEncoding]; //结束添加对象到data中

 

       [archivrelease];

 

       [datawriteToFile:homePath atomically:YES];//将data写到文件中保存在磁盘上

 

       NData*content=[NSDatadataWithConenteOfFile:homePath];

 

       NSKeyedUnarchiv*unarchiv=[[NSKeyedUnarchivalloc]initForReadingWithData:content];

 

       floatag=[unarchivdecodeFloatForKey:@"age"];

 

       NSStr*name=[unarchivdecodeObjectForKey:@"name"];


        在iOS开发中,除了归档问题,往往不注意的是安全问题。别以为,就Android会爆漏洞,早在WireLurker出现的时候,iOS的安全神话就已经不复存在了。而目前在国内,iOS安全加密保护这块还是空白。但是,广大iOS开发者也不必担心,因为就在前不久,已经有平台推出了iOS应用加密服务,针对iOS的技术原理和破解原理,分别从本地数据、方法体/方法名、URL编码、程序结构、网络传输数据等几个方面对iOS应用进行全方位的保护,并可以根据iOS应用用户的需求提供定制解决方案,从而实现iOS防破解保护。iOS应用加密http://www.ijiami.cn/ios

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29985911/viewspace-1348268/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/29985911/viewspace-1348268/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值