国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

OC-13.數據解析(JSON與XML)

2019-11-14 18:00:40
字體:
來源:轉載
供稿:網友

##數據交互格式


  • 服務器返回給用戶的數據,通常是以下兩種方式:
  • 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的屬性值,將其轉化為字符串對象    */}

     

 
 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 瑞丽市| 科技| 弥勒县| 固镇县| 平山县| 满城县| 偃师市| 睢宁县| 德钦县| 扶余县| 昭通市| 北票市| 平果县| 宜良县| 墨玉县| 于田县| 海晏县| 克山县| 抚松县| 吐鲁番市| 万年县| 沽源县| 瓮安县| 进贤县| 黄骅市| 桑日县| 宁武县| 壶关县| 叙永县| 河西区| 巢湖市| 正阳县| 会宁县| 龙口市| 宁津县| 宝清县| 泌阳县| 泸定县| 乳源| 城固县| 彰武县|