JSON
1.JSON是一種輕量級的數據格式,一般都是用于數據交互
2.服務器返回給客戶端的數據,一般都是JSON格式或者XML格式(文件下載除外)
3.JSON的格式很像OC中的字典和數組
{"name" : ["jim","jack","rose"] ,"age" : 10}
標準的JSON格式注意點:key必須用雙引號
4.想要從JSON中挖掘數據,就得對JSON進行解析
JSON--->OC數據類型
5.對于JSON數據的解析,我們推薦用蘋果原生:NSJSONSerialization(性能最好)
常用方法有:
JSON--->OC對象[我們稱之為JSON數據序列化--一般轉化成OC中的字典,或者數組. 具體根據傳入的JSON數劇算]
+ (id)JSONObjectWithData:() options:(NSJSONReadingOptions)opt error:(NSError **)error
OC對象--->JSON數據[我們稱之為JSON數據的反序列化--也就是將數據轉換為JSON數據]
+ (NSData *)dataWithJSONObject:(id)obj options:(NSJSONWritingOptions)opt error:(NSError *)error
序列化
NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login?username=520it&pwd=520it&type=JSON"];
NSURLRequest *request = [NSURLRequest requestWithURL:url];
[NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
// 將相應數據data ,轉換成json數據。
// 第一個參數: 需要轉換的data
// 第二個參數:關于 數據顯示后的一些配置
/*
NSJSONReadingMutableContainers = (1UL << 0),解析出來的數組和字典是可變的(可變容器)
NSJSONReadingMutableLeaves = (1UL << 1), 解析出來的字符串是可變的(ios7 以前用的)
NSJSONReadingAllowFragments = (1UL << 2) 被解析的數據 既不是字典 也不是字符串的時候
NSNumber,NSBOOLen NSNULL(對象,用于占位的),nil(0)
*/
NSString *str = [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding ];
NSData *json = [NSJSONSerialization JSONObjectWithData:data options: NSJSONReadingMutableContainers error:nil];
NSLog(@"%@-----%@",str,json);
}];
#######反序列化
NSDictionary *dict = @{
@"name":@"小明",
@"age":@16,
@"schools":@[
@{@"小學":@"123"},
@{@"初中":@"456"},
@{@"大學":@"789"}
],
};
// 對象轉換成 json ,
// 第一個參數:傳入需要轉換的對象
// 對象轉換以后的排版方式,沒什么意義
NSData *data = [NSJSONSerialization dataWithJSONObject:dict options:kNilOptions error:nil];
NSLog(@"%@",[[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding]);
為了讓序列化出來出來的數組,在控制臺的打印清晰明了,于是重寫了[NSDictionary,NSArray加分類, 然而可以直接寫在一個.m文件中, 只是按照分類寫法就行了, 一個文件中允許有兩個@implementation ,但是不能嵌入式使用. 重寫的方法在調用 NSLog時 會自動調用, 這個方法就是為了格式固定的,以及調試使用] - (NSString *)descriptionWithLocale:(id)locale
- (NSString *)descriptionWithLocale:(id)locale
#import <Foundation/Foundation.h>
@implementation NSDictionary (LXL)
- (NSString *)descriptionWithLocale:(id)locale
{
// 1.定義字符串保存的拼接結果。
NSMutableString *strMut = [NSMutableString string];
[strMut appendString:@"{\n"];
[self enumerateKeysAndObjectsUsingBlock:^(id key, id obj, BOOL *stop) {
[strMut appendFormat:@"\t%@:%@\n",key,obj];
}];
[strMut appendString:@"}\n"];
return strMut;
}
@end
@implementation NSArray (LXL)
- (NSString *)descriptionWithLocale:(id)locale
{
// 1.定義字符串保存的拼接結果。
NSMutableString *strMut = [NSMutableString string];
[strMut appendString:@"(\n"];
[self enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
[strMut appendFormat:@"%@\n",obj];
}];
[strMut appendString:@")\n"];
return strMut;
}
@end
在項目中一般介紹到的JSON數據,都是將其轉換成模型數據進行保存, 更有方便的方法,就是將其轉換成plist文件保存在文件沙盒中, 方便讀取. (這是關于文件的持久化的管理)
XML
基本介紹
1.全稱:Extension Markup Language : 可擴展標記語言
2.交互數據格式 html語言 DOM標簽組成
3.組成部分: 文檔聲明[相當于Html中的header], 元素
(Element),屬性(Attribute)
解析方式:
DOM:一次性將整個XML文檔加載進內存,比較適合解析小文件
SAX:從根元素開始,按順序一個元素一個元素往下解析,比較適合大文件的解析
iOS中的XML解析
解析方式: NSXMLParser(大小),使用方便 ,
三方框架GDataXML(小)
下面來介紹GDataXML的使用
1.GDataXML基于libxml2庫, 必須導入libxml2庫(添加依賴庫)
2.因為GDataXML是非ARC,所以需要混編 ,混編方法
GDataXML中的常用類
1.GDataXMLDocument:帶便整個XML文檔
2.GDataXMLElement:代表文檔中的每一個元素
使用attributeForName:
方法可以獲取屬性值
NSString *urlStr = @"http://120.25.226.186:32812/video?type=XML";
NSURL *url = [NSURL URLWithString:urlStr];
// 設置請求
NSURLRequest *request = [NSURLRequest requestWithURL:url];
// 發送異步請求,獲取服務器數據
[NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
// 將接收到的數據轉換為 xml文件
GDataXMLDocument *document = [[GDataXMLDocument alloc]initWithData:data options:kNilOptions error:nil];
// 獲取文檔中的每一個元素(外層)
GDataXMLElement *element = document.rootElement;
// 打印驗證所有元素
NSLog(@"%@",element);
// 獲取 元素中的內容 (內層元素)
NSArray *elements = [element elementsForName:@"video"];
for (GDataXMLElement *element in elements) {
VideoModel *model = [[VideoModel alloc]init];
// 取出每一個子元素中的屬性, 再給模型賦值保存數據
model.name = [element attributeForName:@"name"].stringValue;
model.url = [element attributeForName:@"url"].stringValue;
model.image = [element attributeForName:@"image"].stringValue;
model.length = [element attributeForName:@"length"].stringValue.intValue;
[self.videos addObject:model];
[self.tableView reloadData];
}
}];
下面來介紹NSXMLParser的使用
使用步驟
1.傳入XML數據,創建解析器
NSXMLParser *parser = [[NSXMLParser alloc]initWithData:Data]
2.設置代理,監聽解析過程
parser.delegate = self
3.開始解析
[parser parse]
NSXMLParser采用的是SAX方式解析,特點是事件驅動,下面情況都會通知代理
1.當掃描到文檔Document的開始與結束
2.當掃描到元素Element的開始和結束
NSXMLParserDelegate的代理方法
1.當掃描到文檔的開始時調用(開始解析)
- (void)parserDidStartDocument:(NSXMLParser *)parser
2.當掃描到文檔的結束時調用(解析完畢)
- (void)parserDidEndDocument:(NSXMLParser *)parser
3.當掃描到元素開始時調用(attributeDict存放著元素的屬性)
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *) nsmespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict
4.當掃描到元素的結束時調用
- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName (NSString *)qName
在實際應用中的使用方法:
// 將解析的每一元素,進行轉換,存儲,可以存儲在plist文件中,也可以保存在模型數據中
// 開始解析xml中的每一個元素,從大到小
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict
{
// 將解析到的字典屬性, 進行模型轉換
VideoModel *model = [VideoModel objectWithKeyValues:attributeDict];
// 將模型添加到模型數組
[self.videos addObject:model];
// 每添加一組,進行數據更新
[self.tableView reloadData];
}