ios网络学习------6 json格式数据的请求处理
- #import "MainViewController.h"
- #import "Video.h"
- #define kBaseURL @"http://192.168.3.252/~apple"
- @interface MainViewController ()<UITableViewDataSource, UITableViewDelegate>
- @property (strong, nonatomic) NSArray *dataList;
- @property (weak, nonatomic) UITableView *tableView;
- @end
- @implementation MainViewController
- </pre><p class="p1">/*</p><p class="p2"><span class="s1"> </span>在网络应用开发中,</p><p class="p2"><span class="s1"> 1 </span>数据是同步加载的,可以保证用户有的看</p><p class="p2"><span class="s1"> 2 </span>图像,音频,视频是异步加载的。可以保证在不阻塞主线程的使用的前提下,用户可以渐渐的看到多媒体信息。</p><p class="p1"> */</p><pre code_snippet_id="412158" snippet_file_name="blog_20140630_1_3481337" name="code" class="objc">
- #pragma mark 实例化视图
- - (void)loadView
- {
- self.view = [[UIView alloc]initWithFrame:[UIScreen mainScreen].applicationFrame];
- //1 tableview
- CGRect frame = self.view.bounds;
- UITableView *tableView = [[UITableView alloc]initWithFrame:CGRectMake(0, 0, frame.size.width, frame.size.height - 44) style:UITableViewStylePlain];
- //1)数据源
- [tableView setDataSource:self];
- //2)代理
- [tableView setDelegate:self];
- //)设置表格高度
- [tableView setRowHeight:80];
- [self.view addSubview:tableView];
- self.tableView = tableView;
- //toolBar
- UIToolbar *toolBar = [[UIToolbar alloc]initWithFrame:CGRectMake(0, tableView.bounds.size.height, 320, 44)];
- [self.view addSubview:toolBar];
- //添加toolbar按钮
- UIBarButtonItem *item1 = [[UIBarButtonItem alloc]initWithTitle:@"load json" style:UIBarButtonItemStyleDone target:self action:@selector(loadJson)];
- UIBarButtonItem *item2 = [[UIBarButtonItem alloc]initWithTitle:@"load xml" style:UIBarButtonItemStyleDone target:self action:@selector(loadXML)];
- UIBarButtonItem *item3 = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace target:nil action:nil];
- [toolBar setItems:@[item3, item1, item3, item2, item3]];
- }
- #pragma mark -uitableview数据源方法 对于uitableview下面这两个方法是必须实现的。
- - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
- {
- return self.dataList.count;
- }
- //每填充一行都调用一次这个方法。知道界面上的所有行都填充完毕。,
- - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
- {
- //使用可充用标示符查询可重用单元格
- static NSString *ID = @"MyCell";
- UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];
- if (cell == nil) {
- cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:ID];
- }
- //设置单元格内容
- Video *v = self.dataList[indexPath.row];
- cell.textLabel.text = v.name;
- cell.detailTextLabel.text = v.teacher;
- //加载图片
- //1)同步加载网络图片,同步方法以为这这些指令在完成之前,后续指令都无法执行。
- //注意:在开发网络应用时,不要使用同步方法加载图片,否则会严重影响用户体验
- // NSString *imagePath = [NSString stringWithFormat:@"%@%@", kBaseURL, v.imageURL];
- // NSURL *imageUrl = [NSURL URLWithString:imagePath];
- // NSData *imageData = [NSData dataWithContentsOfURL:imageUrl];
- // UIImage *image = [UIImage imageWithData:imageData];
- //
- // //2)异步加载网络图片
- // //网络连接本身就有异步命令 sendAsync
- // [cell.imageView setImage:image];
- //如果缓存图像不存在
- if (v.cacheImage == nil) {
- //使用默认图像占位,即能够保证有图像,又能够保证有地方。
- UIImage *image = [UIImage imageNamed:@"user_default.png"];
- [cell.imageView setImage:image]; //使用默认图像占位
- //开启异步连接,加载图像,因为加载完成之后,需要刷新对应的表格航
- [self loadImageAsyncWithIndexPath:indexPath];
- }else
- {
- [cell.imageView setImage:v.cacheImage];
- }
- //[self loadImageAsyncWithUrl:imageUrl imageView:cell.imageView];
- return cell;
- }
- #pragma mark 异步加载网络图片
- //由于uitableview是可重用的,为了避免用户快速频繁刷新表格,造成数据冲突,不能直接将uiimageview传入异步方法
- //正确的解决方法是:将表格行的indexpath传入异步方法,加载完成图像以后,直接刷新指定的行。
- - (void)loadImageAsyncWithIndexPath:(NSIndexPath *)indexPath
- {
- Video *v = self.dataList[indexPath.row]; //取出当前要填充的行
- NSString *imagePath = [NSString stringWithFormat:@"%@%@", kBaseURL, v.imageURL];
- NSURL *imageUrl = [NSURL URLWithString:imagePath];
- //NSLog(@"%@ %@", url, imageView);
- //1 request
- NSURLRequest *request = [NSURLRequest requestWithURL:imageUrl];
- //2 connection sendasync异步请求
- [NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *error) {
- //UIImage *image = [UIImage imageWithData:data];
- //[imageView setImage:image];
- //将网络数据保存至缓存图像。
- v.cacheImage = [UIImage imageWithData:data];
- //刷新表格
- [self.tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationLeft];
- }];
- }
- #pragma mark 处理json数据
- - (void)handlerJSONData:(NSData *)data
- {
- //json文件中的[]表示一个数据。
- //反序列化json数据
- /*
- 序列化: 将一个nsboject转换成序列数据,以便通过互联网进行传输。
- 反序列化:将网络上获取的数据反向生成我们需要的对象。
- */
- //第二个参数是解析方式,一般用NSJSONReadingAllowFragments
- NSArray *array = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingAllowFragments error:nil];
- NSLog(@"%@", array); //json解析以后是nsarray格式的数据。
- //提示:如果开发网络应用,可以将反序列化出来的对象,保存至沙箱,以便后续开发使用。
- NSArray *docs = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
- NSString *path = [docs[0]stringByAppendingPathComponent:@"json.plist"];
- [array writeToFile:path atomically:YES]; //把array里面的数据写入沙箱中的jspn.plist中。
- //给数据列表赋值
- NSMutableArray *arrayM = [NSMutableArray array];
- for (NSDictionary *dict in array) {
- Video *video = [[Video alloc]init];
- //给video赋值
- [video setValuesForKeysWithDictionary:dict];
- [arrayM addObject:video];
- }
- self.dataList = arrayM;
- //刷新表格
- [self.tableView reloadData];
- NSLog(@"%@", arrayM); //这句话将调用video里面的description和nsarray+log里面的descriptionWithLocale
- }
- #pragma mark 加载json
- - (void)loadJson
- {
- NSLog(@"load json");
- //从web服务器加载数据
- NSString *str = @"http://www.baidu.com?format=json"; //这里是乱写的
- //提示:NSData本身具有同步方法,但是在实际开发中,不要使用次方法
- //在使用NSData的同步方法时,无法指定超时时间,如果服务器连接不正常,会影响用户体验。
- //NSData *data = [NSData dataWithContentsOfURL:[NSURL URLWithString:str]];
- //简历NSURL
- NSURL *url = [NSURL URLWithString:str];
- //建立NSURLRequest
- NSURLRequest *request = [NSURLRequest requestWithURL:url cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:2.0f];
- //建立NSURLConnect的同步方法加载数据
- NSURLResponse *response = nil;
- NSError *error = nil;
- //同步加载数据
- NSData *data = [NSURLConnection sendSynchronousRequest:request returningResponse:&response error:&error];
- //错误处理
- if (data != nil) {
- //下面这两句话本身没有什么意义,仅用于跟踪调试。
- NSString *result = [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding];
- NSLog(@"%@", result);
- //在处理网络数据的时候,不要将NSData转换成nsstring。
- [self handlerJSONData:data];
- }else if (data == nil && error == nil){
- NSLog(@"空数据");
- }else
- {
- NSLog(@"%@", error.localizedDescription);
- }
- }
- #pragma mark 加载xml
- - (void)loadXML
- {
- NSLog(@"load xml");
- }
- //- (void)viewDidLoad
- //{
- // [super viewDidLoad];
- //}
- @end
ios网络学习------6 json格式数据的请求处理的更多相关文章
- ios网络学习------8 xml格式数据的请求处理 用代码块封装
#pragma mark 载入xml - (void)loadXML { //获取网络数据. NSLog(@"load xml"); //从webserver载入数据 NSStri ...
- iOS开发之JSON格式数据的生成与解析
本文将从四个方面对IOS开发中JSON格式数据的生成与解析进行讲解: 一.JSON是什么? 二.我们为什么要用JSON格式的数据? 三.如何生成JSON格式的数据? 四.如何解析JSON格式的数据? ...
- ios网络学习------4 UIWebView的加载本地数据的三种方式
ios网络学习------4 UIWebView的加载本地数据的三种方式 分类: IOS2014-06-27 12:56 959人阅读 评论(0) 收藏 举报 UIWebView是IOS内置的浏览器, ...
- 转载 -- iOS开发之JSON格式数据的生成与解析
本文将从四个方面对IOS开发中JSON格式数据的生成与解析进行讲解: 一.JSON是什么? 二.我们为什么要用JSON格式的数据? 三.如何生成JSON格式的数据? 四.如何解析JSON格式的数据? ...
- Spring MVC 学习笔记11 —— 后端返回json格式数据
Spring MVC 学习笔记11 -- 后端返回json格式数据 我们常常听说json数据,首先,什么是json数据,总结起来,有以下几点: 1. JSON的全称是"JavaScript ...
- JS学习笔记(3)--json格式数据的添加,删除及排序方法
这篇文章主要介绍了json格式数据的添加,删除及排序方法,结合实例形式分析了针对一维数组与二维数组的json格式数据进行增加.删除与排序的实现技巧,需要的朋友可以参考下 本文实例讲述了json格式 ...
- 解析json格式数据
实现目标 读取文件中的json格式数据,一行为一条json格式数据.进行解析封装成实体类. 通过google的Gson对象解析json格式数据 我现在解析的json格式数据为: {",&qu ...
- Android读取JSON格式数据
Android读取JSON格式数据 1. 何为JSON? JSON,全称为JavaScript Object Notation,意为JavaScript对象表示法. JSON 是轻量级的文本数据交换格 ...
- 使用基于Android网络通信的OkHttp库实现Get和Post方式简单操作服务器JSON格式数据
目录 前言 1 Get方式和Post方式接口说明 2 OkHttp库简单介绍及环境配置 3 具体实现 前言 本文具体实现思路和大部分代码参考自<第一行代码>第2版,作者:郭霖:但是文中讲 ...
随机推荐
- mybatis代码生成(generator工具生成代码)
generator工具生成代码 下载地址 http://pan.baidu.com/s/1bY8C0I
- hibernate映射的 关联关系:有 一对多关联关系,一对一关联关系,多对多关联关系,继承关系
hibernate环境配置:导包.... 单向n-1:单向 n-1 关联只需从 n 的一端可以访问 1 的一端 <many-to-one> 元素来映射组成关系: name: 设定待映射的持 ...
- iOS 枚举的巧用
前言 在之前的一篇文章中简单的提到了这个问题, 但是自己写的不详细, 并且自己深入了解的也不是特别多, 在开发中也没怎么用到,所以经过阅读者的反馈对这个问题很是疑惑! 本篇文章会分析之前的不足之处, ...
- easyui datagrid 行右键生成 动态获取(toolbar) 按钮
var createGridRowContextMenu = function(e, rowIndex, rowData) { e.preventDefault(); var grid = $(thi ...
- StudyFoxCMS-8
1.swiper插件使用 首页图片滚动插件. (1)下载:bower install swiper (2)使用:参考中文官网(http://www.swiper.com.cn/usage/index. ...
- HTTP笔记之一
1 URL 统一资源定位符(URL)是资源标识符最常见的格式.大部分的URL都遵循一种标准格式,这种格式包含三个部分. URL的第一部分:方案(scheme),说明了访问资源所使用的协议类型.通常是 ...
- aws在线技术峰会笔记-基于AWS的Devops最佳实践
AWS CodeCommit AWS CodePipeline 可以和github集成 可以支持蓝绿部署 微服务架构, API Gateway进行转发
- Mysql 中有关日期的函数(sql)
DAYOFWEEK(date)返回日期date的星期索引(1=星期天,2=星期一, ……7=星期六).这些索引值对应于ODBC标准.mysql> select DAYOFWEEK('1998-0 ...
- servlet学习笔记_1
一.动态页面和静态页面 动态页面&静态页面:如果浏览器在不同时刻不同条件下访问web服务器的某个页面,浏览器所获得的页面内容会发生变化,那么这种页面称之为动态页面.动态页面和静态页面的区别在于 ...
- Nbimer族助手 部分控件不能用的解决方法(转)
用户提出的问题现象: 我两天笔记本安装的都是win7 SP1系统,一台为64为一台为32位,网络环境是移动宽带通过D-Link路由器实现无线局域网,DHPC自动分配IP地址.每次打开IE或者Chrom ...