iOS-归档模型创建和工具类的封装
来源:互联网 发布:golang cobra 编辑:程序博客网 时间:2024/05/29 18:28
数据的存储方式有好多种 plist NSUserDefault CoreData fmdb 归档
这些方式各自有优缺点
如果我们存储数据量小的数据 可以使用归档和 NSUserDefault
今天讲解一个知识点 归档的使用
这里是为实现了一个功能 用户登录和注册
我们将信息保存起来 下次打开应用程序 直接从沙盒中读取比对判断 十分方便
这里封装了一个用户模型 和 一个工具类 大家可以拿来直接使用
代码如下:注解很详细
#import <Foundation/Foundation.h>#warning 这里必须遵守协议 不然不知道对象中的哪些属性写进沙盒@interface QHAccount : NSObject<NSCoding>//返回字段 字段类型 字段说明/**string 登录状态 返回值1 表示登录成功 返回值0表示登录失败*/@property (nonatomic, copy) NSString *status;/**string 记录登录状态信息:登录成功/登录失败*/@property (nonatomic, copy) NSString *data;/**string userid 用户的id 编号唯一*/@property (nonatomic, copy) NSString *userid;/**string mobile电话号码*/@property(nonatomic, copy)NSString *mobile;/**string nickname昵称 用于保存用户的昵称*/@property (nonatomic, copy) NSString *nickname;/**string 登录成功后返回token值*/@property (nonatomic, copy)NSString *token;+ (instancetype)accountWithDict:(NSDictionary *)dict;@end
#import "QHAccount.h"@implementation QHAccount+ (instancetype)accountWithDict:(NSDictionary *)dict{ QHAccount *account = [[self alloc]init]; account.status = dict[@"status"]; account.data = dict[@"data"]; account.userid = dict[@"userid"]; account.mobile = dict[@"mobile"]; account.nickname = dict[@"nickname"]; account.token = dict[@"token"]; return account;}/** * 当一个对象要归档到沙盒中的时候 就会调用这个方法 目的:在这个方法中说明这个对象的哪些属性要存进沙盒 */- (void)encodeWithCoder:(NSCoder *)aCoder{ [aCoder encodeObject:self.status forKey:@"status"]; [aCoder encodeObject:self.data forKey:@"data"]; [aCoder encodeObject:self.userid forKey:@"userid"]; [aCoder encodeObject:self.mobile forKey:@"mobile"]; [aCoder encodeObject:self.nickname forKey:@"nickname"]; [aCoder encodeObject:self.token forKey:@"token"];}/** * 当从沙盒中解档一个对象(从沙盒中加载一个对象)就要调用该方法 目的:在这个方法中说明沙盒中的属性该怎么解析(需要取出哪些属性) */- (id)initWithCoder:(NSCoder *)aDecoder{ if (self = [super init]) { self.status = [aDecoder decodeObjectForKey:@"status"]; self.data = [aDecoder decodeObjectForKey:@"data"]; self.userid = [aDecoder decodeObjectForKey:@"userid"]; self.mobile = [aDecoder decodeObjectForKey:@"mobile"]; self.nickname = [aDecoder decodeObjectForKey:@"nickname"]; self.token = [aDecoder decodeObjectForKey:@"token"]; } return self;}@end
#import <Foundation/Foundation.h>#import "QHAccount.h"@interface QHAccountTool : NSObject/** * 存储用户的账号信息 * * @param account <#account description#> */+ (void)saveAccount:(QHAccount *)account;/** * 返回账号信息 * * @return <#return value description#> */+ (QHAccount *)account;@end
//处理账号所有的有关信息存储账号 验证账号
#define QHAccountPath [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)lastObject] stringByAppendingPathComponent:@"account.archive"]
#import "QHAccountTool.h"
@implementation QHAccountTool
/**
* 存储用户的账号信息
*
* @param account <#account description#>
*/
+ (void)saveAccount:(QHAccount *)account
{
//放进document可以进行备份
//将返回的数据存进沙盒
// NSString *doc = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)lastObject];
#warning 这里的NSString 方法调用出错用的是stringByAppending 路径拼接错误
// NSString *path = [doc stringByAppendingPathComponent:@"account.archive"];
//存进沙盒
//[responseObject writeToFile:path atomically:YES];
//自定义对象的存储必须用NSKeyedArchiver不在有什么write to file
[NSKeyedArchiverarchiveRootObject:account toFile:QHAccountPath];
}
/**
* 返回账号信息
*
* @return <#return value description#>
*/
+ (QHAccount *)account
{
//加载数据模型
QHAccount *account = [NSKeyedUnarchiverunarchiveObjectWithFile:QHAccountPath];
return account;
}
@end
- iOS-归档模型创建和工具类的封装
- ios开发-懒加载和模型的封装
- iOS 归档 和 自定义归档
- ios中 继承对象模型的归档实现
- iOS - 归档的理解和摘记
- iOS练习 微博QQ oAuth授权 MJExtension的模型归档与解归档
- iOS激情详解之文件夹创建,移动,复制,删除以及归档和反归档
- ios-音乐播放器(2)工具类的封装
- 封装的工具类
- IOS COREDATA SWIFT 创建关系和新建模型类
- iOS中实现归档和反归档
- iOS 归档的使用
- IOS的归档
- IOS的归档
- iOS 归档的记录
- iOS 归档的记录
- ios创建视图的一些方法封装
- ios ---对模型对象归档(NSKeyedArchiver、NSKeyedUnarchiver)
- Linux下TCP客户端和服务器代码编写
- 第八周 串 项目2 -- 建立链串的算法库
- [Leetcode] Word Ladder
- cookies编程
- 第4周项目6 多项式求和
- iOS-归档模型创建和工具类的封装
- iOS讲解迷惑之键盘弹出遮挡输入框的问题
- 第三周项目4—顺序表的应用(2)
- 第六周项目4-数制转换
- servlet容器和web容器
- 第四周项目 猴子选大王
- 数组转化成批查询条件
- spring3.0自带的定时任务重复执行两次
- 第6周 项目1-建立顺序栈算法库