美文网首页
JSON&&XML解析笔记

JSON&&XML解析笔记

作者: 松n_n鼠 | 来源:发表于2017-12-05 10:06 被阅读0次

    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 :不懂技术的爱迪生

    相关文章

      网友评论

          本文标题:JSON&&XML解析笔记

          本文链接:https://www.haomeiwen.com/subject/dduwbxtx.html