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

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

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的屬性值,將其轉化為字符串對象	*/}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 阳西县| 苗栗市| 辰溪县| 朔州市| 湘西| 罗源县| 仁寿县| 乐安县| 武乡县| 定南县| 旬邑县| 清苑县| 团风县| 定州市| 阳春市| 昌平区| 宜州市| 郸城县| 韶山市| 长乐市| 监利县| 宁波市| 通州区| 丹江口市| 桦川县| 华宁县| 民和| 石台县| 英山县| 荣昌县| 潜山县| 美姑县| 南丹县| 湖州市| 乾安县| 江川县| 宁乡县| 夏河县| 墨竹工卡县| 镇沅| 宕昌县|