·您现在的位置: 云翼网络 >> 文章中心 >> 网站建设 >> app软件开发 >> IOS开发 >> OC-13.数据解析(JSON与XML)

OC-13.数据解析(JSON与XML)

作者:佚名      IOS开发编辑:admin      更新时间:2022-07-23

##数据交互格式


  • 服务器返回给用户的数据,通常是以下两种方式:
    • 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的属性值,将其转化为字符串对象
        */
    }