IOS之網路數據下載和JSON解析 簡介 在本文中筆者將要給大家介紹IOS中如何利用URLConnection從網路上下載數據,如何解析下載下來的JSON數據格式,以及如何顯示數據和圖片的一部下載顯示 涉及到的知識點: 1.URLConnection非同步下載和封裝 2.JSON格式和JSON格式解析 ...
IOS之網路數據下載和JSON解析
簡介
在本文中筆者將要給大家介紹IOS中如何利用URLConnection從網路上下載數據,如何解析下載下來的JSON數據格式,以及如何顯示數據和圖片的一部下載顯示
涉及到的知識點:
1.URLConnection非同步下載和封裝
2.JSON格式和JSON格式解析
3.數據顯示和使用SDWebImage非同步顯示圖片
內容
1.網路下載基礎知識介紹
什麼是網路應用?
需要連接網路的應用,例如:微信,QQ,足記等;
而電腦,相機,日曆等不需要連接網路的稱為本地應用。
網路應用的程式結構
需要有客戶端和服務端
服務端是為客戶端服務的,服務的內容諸如向客戶端提供資源,保存客戶端數據。
客戶端(Client)或稱為用戶端,是指與伺服器相對應,為客戶提供本地服務的程式
常用的網路介面形式
IOS網路應用常見的數據介面一半都是HTTP形式的URL地址;
其他的網路數據介面 :http,ftp,https
常見的數據格式
IOS開發中常見的數據格式有兩種, 一種是JSON格式, 另外種是XML格式, 相對來說, JSON格式使用的比較多占了75%,XML占了20%,其餘的占5%
界面開發的一般流程
IOS中開發一個界面, 需要界面效果圖, 界面素材資源, 和網路介面
開發的流程一般如下所示
***1, 下載數據
***2, 解析JSON或XML數據, 創建數據模型model
***3, 使用控制項顯示數據, 必要的時候定製視圖, 例如定製cell
2.URLConnection使用
NSString 同步下載
NSString *urlString = @"http://iappfree.candou.com:8080/free/applications/limited?currency=rmb&page=1&category_id="; NSLog(@"%@",urlString); // 下載數據 // 通過地址生成NSURL對象 NSError *error = nil; NSURL *url = [NSURL URLWithString:urlString]; NSString *content = [[NSString alloc]initWithContentsOfURL:url encoding:NSUTF8StringEncoding error:&error]; if (error == nil) { NSLog(@"content = %@",content); } else{ NSLog(@"下載失敗"); } // 項目中怎麼使用 // 1.同步形式下載,initWithContentsOfURL下載完了之後才會返回造成界面假死,不能使用 // 2.使用非同步下載(NSURLConnection 非同步下載)
NSURLConnection同步下載
NSString *urlString = @"http://iappfree.candou.com:8080/free/applications/limited?currency=rmb&page=1&category_id="; // 發送同步URL請求 // NSURLRequest URL請求 NSURL *url = [NSURL URLWithString:urlString]; NSURLRequest *request = [NSURLRequest requestWithURL:url]; NSError *error = nil; NSData *data = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:&error]; if (error == nil) { NSString *str = [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding]; NSLog(@"str = %@",str); } else{ NSLog(@"下載失敗"); }
NSURLConnection非同步下載
-(void)testtestNSURLConnectionAsyncDownloadData { NSString *urlString = @"http://iappfree.candou.com:8080/free/applications/limited?currency=rmb&page=1&category_id="; // 初始化 _data = [[NSMutableData alloc]init]; // 發起一個非同步的URL連接請求 // 非同步: 執行了方法之後開始下載,立即返回,下載過程在後臺(多線程)執行 _connection = [[NSURLConnection alloc]initWithRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:urlString]] delegate:self startImmediately:YES]; NSLog(@"initWithRequest執行完成"); } //代理方法:接收到伺服器的響應執行 -(void)connection:(NSURLConnection *)connection didReceiveResponse:(NSURLResponse *)response { NSLog(@"接收到伺服器的響應"); } //代理方法:接收到數據的時候執行 //註意:但數據比較大的時候可能多次執行 -(void)connection:(NSURLConnection *)connection didReceiveData:(NSData *)data { [_data appendData:data]; } //代理方法:數據下載完成了 -(void)connectionDidFinishLoading:(NSURLConnection *)connection { NSString *str= [[NSString alloc]initWithData:_data encoding:NSUTF8StringEncoding]; NSLog(@"str = %@",str); // 最簡單的現實名字 // 解析JSON // 作用:JSON數據轉化為NSDictionary或NSArray NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:_data options:NSJSONReadingMutableContainers error:nil]; NSArray *appList = dic[@"applications"]; for (NSDictionary *appDic in appList) { NSLog(@"name = %@",appDic[@"name"]); } } //代理方法:數據下載失敗 -(void)connection:(NSURLConnection *)connection didFailWithError:(NSError *)error { NSLog(@"error = %@",error); }
3.JSON格式說明和格式化工具
{ "list" : [ { "IsXuanZuo" : 0, "Name" : "汪峰2014“峰暴來臨”超級巡迴演唱會 重慶站", "PriceStr" : "180,280,380,480,680,980,1280", "ProjectID" : 66611, "ShowTime" : "2014.11.01", "SiteStatus" : 8, "Summary" : "【先付預告】2014年5月12日12:08開啟先付!", "VenId" : 258, "VenName" : "重慶奧體中心", "cityname" : "重慶市", "priceName" : "180-1280元" }, { "IsXuanZuo" : 0, "Name" : "莫文蔚20周年巡迴演唱會 鄭州站", "PriceStr" : "480,680,880,1280,1680,2014", "ProjectID" : 66313, "ShowTime" : "2014.07.26", "SiteStatus" : 8, "Summary" : "【客戶端專享】480元少量稀缺票客戶端獨家售賣!", "VenId" : 942, "VenName" : "鄭州國際會展中心", "cityname" : "鄭州市", "priceName" : "480-2014元" }, { "IsXuanZuo" : 0, "Name" : "王力巨集2014MUSIC-MANII“火力全開”世界巡迴演唱會—北京站", "PriceStr" : "280,380,480,580,880,1280,1680", "ProjectID" : 66052, "ShowTime" : "2014.06.14", "SiteStatus" : 8, "Summary" : "坦克上臺火力十足,打造音樂戰役!全新演繹經典作品,體驗超凡音樂魅力!", "VenId" : 392, "VenName" : "國家體育場", "cityname" : "北京市", "priceName" : "280-1680元" } ] }
[] 表示數組,對應NSArray
, 表示併列的數據
{} 表示字典,對應NSDictionary
: 表示鍵值對
"xxx" 表示字元串,對應NSString
20 對應NSNumber
JSON格式格式化工具
Jason
Json Editor
線上: http://www.kjson.com/
4.一個完整頁面的實現(包含model的創建,SDWebImage的使用)
效果圖:
我的代碼:下載