在本文中筆者將要給大家介紹IOS中如何利用URLConnection從網絡上下載數據,如何解析下載下來的JSON數據格式,以及如何顯示數據和圖片的一部下載顯示
涉及到的知識點:
1.URLConnection異步下載和封裝
2.JSON格式和JSON格式解析
3.數據顯示和使用SDWebImage異步顯示圖片
需要連接網絡的應用,例如:微信,QQ,足記等;
而計算機,相機,日歷等不需要連接網絡的稱為本地應用。
需要有客戶端和服務端
服務端是為客戶端服務的,服務的內容諸如向客戶端提供資源,保存客戶端數據。
客戶端(Client)或稱為用戶端,是指與服務器相對應,為客戶提供本地服務的程序
IOS網絡應用常見的數據接口一半都是HTTP形式的URL地址;
其他的網絡數據接口 :http,ftp,https
IOS開發中常見的數據格式有兩種, 一種是JSON格式, 另外種是xml格式, 相對來說, JSON格式使用的比較多占了75%,XML占了20%,其余的占5%
IOS中開發一個界面, 需要界面效果圖, 界面素材資源, 和網絡接口
開發的流程一般如下所示
***1, 下載數據
***2, 解析JSON或XML數據, 創建數據模型model
***3, 使用控件顯示數據, 必要的時候定制視圖, 例如定制cell
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);}
{ "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/
效果圖:
我的代碼:下載
新聞熱點
疑難解答