数据交互格式
- 服务器返回给用户的数据,通常是以下两种方式:
- JSON
- XML
- JSON
- 一种轻量级的数据数据格式,体积比XML小,是服务器返回给移动端通常采用的格式
- 用使用JSON文件中的数据,需要对其进行解析,苹果的NSJSONSerialization解析性能最好
- iOS中的JSON文件解析,是将其转换成OC对象,如下:
- 大括号{} --> 字典NSDictionary
- 中括号[] --> 数组NSArray
- 双引号"" --> 字符串NSString
- 数字 --> NSNumber
- JSON通常使用NSJSONSerialization进行解析,性能最好
- XML
- XML(Extension Markup Language),可扩展标记语言
- 是服务器返回客户端常用的一种数据格式
- XML文档,通常包含以下内容
- 文档声明
- 元素(element)
- 属性(attribute)
- XML文档的解析方案
- 小文件:NSXMLParser苹,果原生
- 大文件:GDataXML,Google开发,基于libxml2
JSON解析
-
解析类型
- 默认解析NSDictionary与NSArray类型的数据
- 若要解析NSString类型的数据,需要使用NSJSONReadingAllowFragments参数
-
一个对象通常要遵循以下规则才能转换成JSON文档
- 根节点是NSDictionary或NSArray类型
- 所有的对象必须是NSString、NSNumber、NSArray、NSDictionary或NSNull中的一种
- 对象个数有限
-
JSON数据与OC对象的转化
- JSON --> OC
+ (nullable id)JSONObjectWithData:(NSData *)data options:(NSJSONReadingOptions)opt error:(NSError **)error /** * data:需要解析的NSData类型数据 * opt:解析方式 * error:错误信息 */
- OC --> Json
+ (nullable NSData *)dataWithJSONObject:(id)obj options:(NSJSONWritingOptions)opt error:(NSError **)error /** * obj:需要转换的OC对象 * opt:解析方式 * error:错误信息 */
-
解析NSString
NSString *json = "I am a coder"; [NSJSONSerialization JSONObjectWithData:[json dataUsingEncoding:NSUTF8StringEncoding] options:NSJSONReadingAllowFragments error:nil] /** * JSON解析的数据通常是使用NSUTF8StringEncoding编码的NSData类型数据 * options:指定可以解析的类型,NSJSONReadingAllowFragments表示可以解析 NSString对象 * error:返回解析错误信息 * 返回值为解析完成的NSString对象 */
-
解析NSDictionary与NSArray(来自服务器的数据)
/**Block的方式发送请求*/ //创建请求对象 NSURLRequest *request = [NSURLRequest requestWithURL:(此处为请求路径)]; //发送请求 [NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue alloc] init] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) { NSDictionary *dict = [NSJSONSerialization JSONObjectWithData:data options:kNilOptions error:nil]; }]; /** * queue:请求任务所在的队列 * completionHandler:请求完成回调的Block * response:服务器的响应信息 * data:服务器返回的数据 * error:错误信息 * 将data解析成对应的NSDictionary对象 */
XML解析
-
小文件解析(NSXMLParser)
- 通过NSXMLParser解析XML文档,需要用到代理协议NSXMLParserDelegate
- NSXMLParserDelegate协议的常用方法
// 1. 开始解析XML文档的时候调用 - (void)parserDidStartDocument:(NSXMLParser *)parser // 2. 解析到XML文档中某个元素的开始的时候调用,解析任务的核心 - (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(nullable NSString *)namespaceURI qualifiedName:(nullable NSString *)qName attributes:(NSDictionary<NSString *, NSString *> *)attributeDict /** * elementName:正在解析的元素的名字 * attributeDict:解析生成的OC对象 */ // 3. 解析到XML文档中某个元素的结束的时候调用 - (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(nullable NSString *)namespaceURI qualifiedName:(nullable NSString *)qName // 4. 解析到XML文档结尾的时候调用 - (void)parserDidEndDocument:(NSXMLParser *)parser
- 解析步骤
// 1. 创建解析器 NSXMLParser *parser = [[NSXMLParser alloc] initWithData:data]; // 2. 设置代理 parser.delegate = self; // 3. 启动解析器 [parser parse]; // 4. 在代理方法中完成具体的解析任务
-
大文件解析(GDataXML)
- 与GDataXML相关的几个类
- GDataXMLDocument,整个XML文档
- GDataXMLElement,XML文档中的一个元素
- 解析步骤
// 1. 将XML文档数据,转换成GDataXMLDocument类型的对象 GDataXMLDocument *document = [[GDataXMLDocument alloc] initWithData:data options:0 error:nil]; // 2. 获取GDataXMLDocument对象中根节点的所有元素 NSArray *elements = [document.rootElement elementsForName:@"此处为元素的名字"]; /** * 获取XML文档中指定名字的所有元素 */ // 3. 解析每个元素中的数据 for (GDataXMLElement *ele in elements) { [ele attributeForName:@"此处为元素中的Key"].stringValue; /** * 解析元素ele中键值为Key的属性值,将其转化为字符串对象 */ }
- 与GDataXML相关的几个类