首页 > 学院 > 开发设计 > 正文

iOS网络-02-数据解析(JSON与XML)

2019-11-14 18:30:01
字体:
来源:转载
供稿:网友

数据交互格式


  • 服务器返回给用户的数据,通常是以下两种方式:

  • 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的属性值,将其转化为字符串对象	*/}

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表