iOS之网络数据下载和Json数据解析
iOS之网络数据下载和Json数据解析
简介
在本文中笔者将要给大家介绍iOS中如何利用NSURLConnection从网络上下载数据,如何解析下载下来的JSON数据,以及如何显示数据和图片的异步下载显示
涉及到的知识点:
1.NSURLConnection异步下载封装
2.JSON格式和JSON格式解析
3.数据显示和使用SDWebImage异步显示图片
内容
1.网络下载基础知识介绍
(1)什么是网络应用?
一般情况下, iPhone的计算机, 照相机不需要从网络上下载数据也能运行, 所以这种类型的应用是本地应用, 但是iPhone上绝大多数的应用都需要网络才能运行, 例如QQ, 微信, 虾米音乐, 所以在iOS开发中需要知道如何从网络上下载数据
(2)网络应用的程序结构
网络应用不同于本地应用, 网络应用的数据是从网络上下载下来的, 所以需要在网络上运行一个程序为应用提供数据, 或者提供服务, 那么这个网络应用一般称为客户端, 而网络上运行的服务称为服务端
(3)常见的网络接口形式
iOS网络应用常见的数据接口一半都是HTTP形式的URL地址, 例如爱限免应用首页的数据地址为http://iappfree.candou.com:8080/free/applications/limited?currency=rmb&page=1&category_id=
在项目中一般使用一些开源库通过这种网址下载数据. 例如AFNetworking
(4)常见的数据格式
iOS开发中常见的数据格式有两种, 一种是JSON格式, 另外种是XML格式, 相对来说, JSON格式使用的比较多
(5)界面开发的一般流程
iOS中开发一个界面, 需要界面效果图, 界面素材资源, 和网络接口
开发的流程一般如下所示
***1, 下载数据
***2, 解析JSON或XML数据, 创建数据模型model
***3, 使用控件显示数据, 必要的时候定制视图, 例如定制cell
2.NSURLConnection使用
NSURLConnection异步下载和同步下载,NSString同步下载
#pragma mark - NSURLConnection异步下载 -(void)testNSURLConnectionAsyncDownloadData { 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数据转化为NSArray或NSDictionary NSDictionary *dict = [NSJSONSerialization JSONObjectWithData:_data options:NSJSONReadingMutableContainers error:nil]; //NSLog(@"dict = %@",dict); //NSArray *appList = dict[@"applications"]; NSArray *appList = [dict valueForKey:@"applications"]; for (NSDictionary *appDict in appList) { NSLog(@"name = %@",appDict[@"name"]); } //NSArray *a = @[@"test",@"vec"]; //NSDictionary *d = @{@"k1":@"v1",@"k2":@"v2"}; //NSLog(@"v = %@",d[@"k1"]); } -(void)connection:(NSURLConnection *)connection didFailWithError:(NSError *)error { NSLog(@"error = %@",error); } #pragma mark - NSURLConnection同步下载 -(void)testNSURLConnectionSyncDownloadData { 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(@"下载失败"); } } #pragma mark - NSString同步下载 -(void)testNSStringDownloadData { // HTTP中使用URL地址 // http:// 地址使用协议(ftp://) // iappfree.candou.com 主机地址(域名和IP) // :8080 主机端口 // /free/applications/limited 网页程序文件路径 // ?currency=rmb&page=1&category_id= 程序参数(参数用&分割) NSString *urlString = @"http://iappfree.candou.com:8080/free/applications/limited?currency=rmb&page=1&category_id="; //下载数据 //通过地址生成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异步下载) }
3.JSON格式说明和格式化工具
//JSON //JavaScript Object Notation /* { "count":20, "data":[ "zhangsan", "lisi", "wangwu" ] } */ //[] 表示数组,对应NSArray //, 表示并列的数据 //{} 表示字典,对应NSDictionary //: 表示键值对 //"ta" 表示字符串,对应NSString //20 对应NSNumber //JSON格式格式化工具 // Jason // Json Editor // 在线: http://www.kjson.com/
4.一个完整页面的实现(包括model的创建,SDWebImage的使用)
效果图: