JSON&&XML解析笔记
2017-12-05 本文已影响0人
松n_n鼠
JSON
iOS中,JSON的常见解析方案有4种
第三方框架:JSONKit、SBJson、TouchJSON(性能从左到右,越右越差)
苹果原生(自带):NSJSONSerialization(性能最好)
NSJSONSerialization常见方法
// JSON数据 --> OC对象(必须掌握)
+ (id)JSONObjectWithData:(NSData *)data options:(NSJSONReadingOptions)opt error:(NSError **)error;
// OC对象 --> JSON数据
+ (NSData *)dataWithJSONObject:(id)obj options:(NSJSONWritingOptions)opt error:(NSError **)error;
JSON解析方案
- 苹果原生(NSJSONSerialization)
- 第三方框架 JSONKit\SBJSON\TouchJSON
JSON转Dic
把json数据转换为OC的dic对象
-(void)jsonToOC
{
// 1.确定url路径
NSURL *url = [NSURL URLWithString:@"接口地址"];
// 2.创建一个请求对象
NSURLRequest *request = [NSURLRequest requestWithURL:url];
// 3.使用NSURLSession发送一个异步请求
[NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *_Nullable response, NSData *_Nullable data, NSError *_Nullable connectionError) {
// 4.当接收到服务器响应的数据后,解析数据(JSON--->OC)
// 第一个参数:要解析的JSON数据,是NSData类型也就是二进制数据
// 第二个参数:解析JSON的可选配置参数
// NSJSONReadingMutableContainers解析出来的字典和数组是可变的
// NSJSONReadingMutableLeaves解析出来的对象中的字符串是可变的 iOS7以后有问题
// NSJSONReadingAllowFragments被解析的JSON数据如果既不是字典也不是数组,那么就必须使用这
// kNilOptions默认写法优化性能
NSDictionary *dict = [NSJSONSerialization JSONObjectWithData:data options:kNilOptions error:nil ];
NSLog(@"%@",dict);
}];
}
OC对象dic->JSON对象
// 1.要转换成JSON数据的OC对象*这里是一个字典
NSDictionary *dictM = @{
@"name":@"wendingding",
@"age":@100,
@"height":@1.72
};
// 2.OC->JSON
// 注意:可以通过+ (BOOL)isValidJSONObject:(id)obj;方法判断当前OC对象能否转换为JSON数据
// 具体限制:
// 1.obj 是NSArray 或 NSDictionay 以及他们派生出来的子类
// 2.obj 包含的所有对象是NSString,NSNumber,NSArray,NSDictionary 或NSNull
// 3.字典中所有的key必须是NSString类型的
// 4.NSNumber的对象不能是NaN或无穷大
// 第一个参数:要转换成JSON数据的OC对象,这里为一个字典
// 第二个参数:NSJSONWritingPrettyPrinted对转换之后的JSON对象进行排版,无意义
NSData *data = [NSJSONSerialization dataWithJSONObject:dictM options:NSJSONWritingPrettyPrinted error:nil];
// 3.打印查看Data是否有值
// 第一个参数:要转换为STring的二进制数据
// 第二个参数:编码方式,通常采用NSUTF8StringEncoding
NSString *strM = [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding];
NSLog(@"%@",strM);
oc对象与JSON数据之间的对应关系
{} -> 字典
[] -> 数组
"" -> 字符串
10/10.1 -> NSNumber
true/false -> NSNumber
null -> NSNull
查看JSON数据结构的方法
- 在线格式化
- 把解析后的数据写plist文件,通过plist文件可以直观的查看JSON的层次结构。
[dictM writeToFile:@"/Users/Desktop/videos.plist" atomically:YES];
字典转模型框架
-
Mantle 需要继承自MTModel
-
JSONModel 需要继承自JSONModel
-
MJExtension 不需要继承,无代码侵入性
MJExtension框架的简单使用
// 1.把字典数组转换为模型数组
// 使用MJExtension框架进行字典转模型
self.videos = [XMGVideo objectArrayWithKeyValuesArray:videoArray];
// 2.重命名模型属性的名称
// 第一种重命名属性名称的方法,有一定的代码侵入性
// 设置字典中的id被模型中的ID替换
+(NSDictionary *)replacedKeyFromPropertyName
{
return @{
@"ID":@"id"
};
}
// 第二种重命名属性名称的方法,代码侵入性为零
[XMGVideo setupReplacedKeyFromPropertyName:^NSDictionary *{
return @{
@"ID":@"id"
};
}];
XML
全称Extensible Markup Language,译作“可扩展标记语言”,也可叫XML文档(XML Document)
一个常见的XML文档一般由以下部分组成
文档声明
元素(Element)
属性(Attribute)
文档声明
在XML文档的最前面,必须编写一个文档声明,用来声明XML文档的类型,encoding说明文档的字符编码。
<?xml version="1.0" encoding="UTF-8" ?>
元素(Element)
一个元素包括了开始标签和结束标签:
- 有元素的标签: <name>变形金刚</name>
- 没有元素的标签以及简写 :<name></name> ; 简 : <name/>
一个元素可以嵌套很多的子元素,但是元素之间不能交叉嵌套,规范的XML文档最多只有一个根元素,且其他的元素都是此根元素的子元素。
!!! 注意:XML中的空格和换行都会被当做具体内容进行处理。
属性(Attribute)
一个元素可以有多个属性,且元素的属性也可以用元素的子元素来表示。
// 属性值必须使用双引号 "" 或者单引号 '' 引住
<video name="变形金刚 第01部" length="180" />
XML的解析
XML有两种解析:
DOM:一次性的将整个XML文档加进内存,适合小文件解析。
SAX: 从根元素开始解析,按照顺序一个一个元素的往下解析,适合大文件解析。
iOS中的XML解析
- 苹果原生解析: NSXMLParser SAX方式解析,使用简单。当出现下面情况都会通知代理
当扫描到文档(Document)的开始与结束
当扫描到元素(Element)的开始与结束
// 传入XML数据,创建解析
NSXMLParser *parser = [[NSXMLParser alloc] initWithData:data];
// 设置代理,监听解析过程
parser.delegate = self;
// 开始解析
[parser parse];
// NSXMLParserDelegate
// 当扫描到文档的开始时调用(开始解析)
- (void)parserDidStartDocument:(NSXMLParser *)parser
// 当扫描到文档的结束时调用(解析完毕)
- (void)parserDidEndDocument:(NSXMLParser *)parser
// 当扫描到元素的开始时调用(attributeDict存放着元素的属性)
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict
// 当扫描到元素的结束时调用
- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName
- 第三方
libxml2 : 纯c语言,默认包含在iOS SDK中,同时支持DOM和SAX方式解析
GDataXML : DOM方式解析,Google开发,基于libxml2
在使用GDataXML的时候需要导入`libxml2.dylib`库
设置libxml2的头文件搜索路径(为了能找到libxml2库的所有头文件)
在Head Search Path中加入/usr/include/libxml2
设置链接参数(自动链接libxml2库)
在Other Linker Flags中加入-lxml2
由于GDataXML是非ARC则需加入 -fno-objc-arc
GDataXML中常用的类
GDataXMLDocument:代表整个XML文档
GDataXMLElement 代表文档中的每个元素
使用attributeForName:方法可以获得属性值
XML解析方式大文件可选:NSXMLParser、libxml2 小文件可选GDataXML
By :不懂技术的爱迪生