iOS中GET 和 POST 网络数据请求

同步请求和异步请求的差别:

1.同步请求,有主线程完成网路请求任务,在数据没有请求之前,用户的所有的交互事件应用都无法处理,会造成一种卡顿现象,影响用户体验

2.异步同步,系统默认开辟子线程完成网络请求任务,主线程依然会处理用户的交互事件,此时不会出现卡顿,一旦开辟子线程就会消耗资源(内存),此时就是拿空间换时间

先分析下整体思路:

1.下面准备一个公用的model数据数据模型:

Business.h

#import <Foundation/Foundation.h>
@interface Business : NSObject
@property(nonatomic,copy)NSString *name;//商户名
@property(nonatomic,copy)NSString *address;//商户地址
@property(nonatomic,copy)NSString *telephone;//电话号码
@property(nonatomic,copy)NSString *title;
@property(nonatomic,copy)NSString *summary;
@end

Business.m

#import "Business.h"
@implementation Business
- (void)dealloc{
    self.name = nil;
    self.telephone = nil;
    self.address = nil;
    self.title = nil;
    self.summary = nil;
    [super dealloc];
}
//防止Crash
- (void)setValue:(id)value forUndefinedKey:(NSString *)key{

}
@end

2.下面准备两个自定义的cell用于两种数据请求的自定义cell:

第一个自定义cell:

BusinessCell.h

#import <UIKit/UIKit.h>
@class Business;
@interface BusinessCell : UITableViewCell
@property (retain, nonatomic) IBOutlet UILabel *nameLabel;
@property (retain, nonatomic) IBOutlet UILabel *adressLabel;
@property (retain, nonatomic) IBOutlet UILabel *telephoneLabel;
//写一个接口给cell上的子控件赋值
- (void)assignValueByBusiness : (Business *)business;
@end

BusinessCell.m

#import "BusinessCell.h"
#import "Business.h"
@implementation BusinessCell

- (void)awakeFromNib {
    // Initialization code
}

//写一个接口给cell上的子控件赋值
- (void)assignValueByBusiness : (Business *)business{

    self.nameLabel.text = business.name;
    self.telephoneLabel.text = business.telephone;
    self.adressLabel.text = business.address;

}
- (void)dealloc {
    [_nameLabel release];
    [_adressLabel release];
    [_telephoneLabel release];
    [super dealloc];
}@end

第二个自定义cell:

CustomCell.h

#import <UIKit/UIKit.h>
@class Business;
@interface CustomCell : UITableViewCell
@property (retain, nonatomic) IBOutlet UILabel *titleLabel;
@property (retain, nonatomic) IBOutlet UILabel *summaryLabel;
//写一个方法给cell上的控件赋值
- (void)setValueByName : (Business *)business;
@end

CustomCell.m

#import "CustomCell.h"
#import "Business.h"
@implementation CustomCell
- (void)dealloc {

    [_titleLabel release];
    [_summaryLabel release];
    [super dealloc];
}
//写一个方法给cell上的控件赋值
- (void)setValueByName : (Business *)business{

    self.titleLabel.text = business.title;
    self.summaryLabel.text = business.summary;
}@end

——————————————开始介绍数据请求:————————————————

GET数据请求(同步请求):

<span style="color:#3333ff;">#import "GETViewController.h"
#import "Business.h"
#import "CustomCell.h"
#import "BusinessCell.h"
@interface GETViewController ()<NSURLConnectionDataDelegate>
@property(nonatomic,retain)NSMutableArray *dataSource;
@property(nonatomic,retain)NSMutableData *data;//拼接多次请求下来的数据
@end

@implementation GETViewController
- (void)dealloc{
    self.dataSource = nil;
    self.data = nil;
    [super dealloc];
}

//懒加载
- (NSMutableArray *)dataSource{
    if (_dataSource == nil) {
        self.dataSource = [NSMutableArray arrayWithCapacity:0];
    }
    return [[_dataSource retain]autorelease];
}

</span><span style="color:#ff0000;">//同步get请求</span><span style="color:#3333ff;">
- (IBAction)handleGetSyncRequst:(UIBarButtonItem *)sender {

    //清空数组
    [self.dataSource  removeAllObjects];

    //1.准备网址字符串
    NSString *urlStr = @"http://api.map.baidu.com/place/v2/search?query=大保健&region=上海&output=json&ak=6E823f587c95f0148c19993539b99295";
    //2.查看网址字符串中是否含有中文,有中文的话要对urlStr进行转码
    NSString *changeUrlStr = [urlStr stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
    //3.创建NSURL对象,不能能够存储本地的文件地址,也能存储网络地址
    NSURL *url = [NSURL URLWithString:changeUrlStr];

    //4.创建网络请求对象(NSURLRequest )
    // NSURLRequest 默认请求方式就是GET请求
    // NSMutableURLRequest  可以设置网络的请求方式
    NSURLRequest *request = [NSURLRequest requestWithURL:url];

    //5.建立同步链接
    //5.1 创建服务器响应对象
    NSURLResponse *response = nil;
    //5.2 创建请求失败错误信息对象
    //以上两个参数都是方法的内部对其赋值
    NSError *error = nil;
    NSData *data = [NSURLConnection sendSynchronousRequest:request returningResponse:&response error:&error];
//    NSLog(@"%@",data); 验证!

    //调用解析方法
    [self parserData:data];

    }
//封装一个解析的方法
- (void)parserData : (NSData *)data{

    //解析:
    NSMutableDictionary *dataDic = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableContainers error:nil];
    //    NSLog(@"%@",dataDic); 验证!
    //取出results key值对应的数组
    NSArray *array = dataDic[@"results"];
    //遍历数组的字典,并使用给Business对象赋值
    for (NSDictionary *dic in array) {
        //创建数据模型对象
        Business *bus = [[Business alloc]init];

        //使用kvc给bus赋值
        [bus setValuesForKeysWithDictionary:dic];

        //添加到存储所有商户信息的数组
        [self.dataSource addObject:bus];
        //释放
        [bus release];
        //        NSLog(@"%@",self.dataSource); 验证!

    }
    //刷新ui界面
    [self.tableView reloadData];
}</span>

GET数据请求(异步请求):

<span style="color:#ff0000;">//异步get请求</span>
- (IBAction)handleGetAsyncRequst:(UIBarButtonItem *)sender {

    //清空数组
    self.dataSource = nil;

    //1.创建网址字符串
    NSString *urlStr = @"http://api.map.baidu.com/place/v2/search?query=大保健&region=上海&output=json&ak=6E823f587c95f0148c19993539b99295";
    //2.判断是否含有中文
    NSString *change = [urlStr stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
    //3.创建NSURL对象
    NSURL *url = [NSURL URLWithString:change];
    //4.创建网络请求
    NSURLRequest *requst = [NSURLRequest requestWithURL:url];
    //5.创建异步网络连接
//    NSOperationQueue  队列类
//    [NSOperationQueue mainQueue]   获取主队类

    /*
    //让当前的self 对象处于引用状态
    __block typeof(self) weakSelf = self;
    [NSURLConnection sendAsynchronousRequest:requst queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
        //data 就是请求下来的数据
        //response 就是响应对象
        //connectionError 就是存放连接时报错信息的对象
        //调用解析方法
        [weakSelf parserData:data];
    }];
    */

   <span style="color:#ff0000;"> //代理完成异步解析</span>
    [NSURLConnection connectionWithRequest:requst delegate:self];

}

代理完成异步解析:

#pragma mark NSURLConnection 代理方法
//当接收到服务器响应的时候触发
- (void)connection:(NSURLConnection *)connection didReceiveResponse:(NSURLResponse *)response{
    //一旦接收到服务器的响应,就创建拼接的data对象
    self.data = [NSMutableData data];
}
//当接收到服务器数据的时候触发
//此方法有可能触发多次,原因:1.网络环境比较差时 2.请求的数据量比较大的时候,此时服务器会分多次把数据传输过来
- (void)connection:(NSURLConnection *)connection didReceiveData:(NSData *)data{
    //拼接服务器传输的数据
    [self.data appendData:data];
}
//当接收到服务器传输数据结束的时候触发
- (void)connectionDidFinishLoading:(NSURLConnection *)connection{
    //此时数据已经接收完毕,可以解析了
    [self parserData:self.data];
}

显示在控件上:

- (void)viewDidLoad {
    [super viewDidLoad];
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

#pragma mark - Table view data source

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
    return 1;
}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {

    return self.dataSource.count;
}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

        BusinessCell *cell = [tableView dequeueReusableCellWithIdentifier:@"getcell" forIndexPath:indexPath];
    //调用cell的控件的赋值方法
    [cell assignValueByBusiness:self.dataSource[indexPath.row]];
    return cell;
}

GET两种数据请求完成!

查看效果:

GET同步和异步数据请求效果:

     ——————————    

————————————————POST数据请求——————————————————————

定义相关属性:

#import "POSTViewController.h"
#import "Business.h"
#import "CustomCell.h"

@interface POSTViewController ()
@property(nonatomic,retain)NSMutableArray *dataSource;
@end

@implementation POSTViewController
- (void)dealloc{
    self.dataSource = nil;
    [super dealloc];
}
- (NSMutableArray *)dataSource{
    if (_dataSource == nil) {
        self.dataSource = [NSMutableArray arrayWithCapacity:0];
    }
    return [[_dataSource retain]autorelease];
}

POST同步数据请求:

//Post同步
//http://ipad-bjwb.bjd.com.cn/DigitalPublication/publish/Handler/APINewsList.ashx/
//date=20131129&startRecord=1&len=5&udid=1234567890&terminalType=Iphone&cid=213
- (IBAction)handlePostSyncRequst:(UIBarButtonItem *)sender {

    [self.dataSource removeAllObjects];

    //1.准备网址字符串
    NSString *urlStr = @"http://ipad-bjwb.bjd.com.cn/DigitalPublication/publish/Handler/APINewsList.ashx/";
    //2.创建NSURL对象
    NSURL *url = [NSURL URLWithString:urlStr];
    //3.创建网络请求对象
    NSMutableURLRequest *requst = [NSMutableURLRequest requestWithURL:url];
    //3.1配置请求方式
    requst.HTTPMethod = @"POST";
    //4.创建参数字符串
    NSString *bodyString = @"date=20131129&startRecord=1&len=5&udid=1234567890&terminalType=Iphone&cid=213";
    //将字符串转换为NSDate独享
    NSData *data = [bodyString dataUsingEncoding:NSUTF8StringEncoding];
    //配置网络请求的方式
    requst.HTTPBody = data;

    //5.创建网络链接
    NSURLResponse *response = nil;
    NSError *error = nil;
  NSData *data1 =  [NSURLConnection sendSynchronousRequest:requst returningResponse:&response error:&error];

//    NSLog(@"%@",data1);

    [self parserData: data1];

}

POST同步数据请求:

//post异步
- (IBAction)handlePostAsyncRequest:(UIBarButtonItem *)sender {

    [self.dataSource removeAllObjects];

    //1.创建网址字符串
    NSString *urlStr =  @"http://ipad-bjwb.bjd.com.cn/DigitalPublication/publish/Handler/APINewsList.ashx/";
    //2.创建NSURL对象
    NSURL *url = [NSURL URLWithString:urlStr];
    //3.创建网络请求对象
    NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url];
    //3.1创建请求方式
 request.HTTPMethod = @"POST";
    //4.创建参数对象
    NSString *bodyString = @"date=20131129&startRecord=1&len=5&udid=1234567890&terminalType=Iphone&cid=213";
    NSData *data = [bodyString dataUsingEncoding:NSUTF8StringEncoding];
    //设置请求对象的body
    request.HTTPBody = data;

    //5.创建网络链接
    __block typeof(self) weakself = self;

  [NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
//      NSLog(@"%@",data);

      [weakself parserData:data];

  }];

}

封装一个解析的方法

- (void)parserData : (NSData *)data{

    //解析:
    NSMutableDictionary *dataDic = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableContainers error:nil];
//        NSLog(@"%@",dataDic); //验证!
    //取出results key值对应的数组
    NSArray *array = dataDic[@"news"];
//    NSLog(@"%@",array);
    //遍历数组的字典,并使用给Business对象赋值
    for (NSDictionary *dic in array) {
        //创建数据模型对象
        Business *bus = [[Business alloc]init];

        //使用kvc给bus赋值
        [bus setValuesForKeysWithDictionary:dic];
//        NSLog(@"%@",bus);
        //添加到存储所有商户信息的数组
        [self.dataSource addObject:bus];
        //释放
        [bus release];
//                NSLog(@"%@",self.dataSource); //验证!

    }
    //刷新ui界面
    [self.tableView reloadData];
}

显示在控件上:

- (void)viewDidLoad {
    [super viewDidLoad];

}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

#pragma mark - Table view data source

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {

    // Return the number of sections.
    return 1;
}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {

    // Return the number of rows in the section.
    return self.dataSource.count;
}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
   CustomCell *cell = [tableView dequeueReusableCellWithIdentifier:@"post" forIndexPath:indexPath];

    [cell setValueByName:self.dataSource[indexPath.row]];

    return cell;
}

POST两种数据请求完成!

查看两种效果效果:

————————————

————————————————————————————————————————————

——————————————介绍同步卡顿现象——————————————————————

BigImageViewController.m

@interface BigImageViewController ()
@property (retain, nonatomic) IBOutlet UIImageView *bigImageView;
@end

@implementation BigImageViewController
- (IBAction)handleKaDun:(UIButton *)sender {

    //1.准备网址字符串
    NSString *urlStr = @"http://f1.topit.me/1/d2/8c/11663656284128cd21o.jpg";

    //2.初始化NSURL对象
    NSURL *url = [NSURL URLWithString:urlStr];

    //3.创建请求对象
    NSURLRequest *request = [NSURLRequest requestWithURL:url];
    //4.建立网络连接
    //4.1创建响应度向
    NSURLResponse  *response = nil;
    NSError *errror = nil;
 NSData *data =   [NSURLConnection sendSynchronousRequest:request returningResponse:&response error:&errror];

    //音乐数据,视频数据,图片数据不需要解析直接可以使用
    self.bigImageView.image = [UIImage imageWithData:data];

}

效果展示:

————————————————————————————————————————————

iOS中GET 和 POST 数据请求的更多相关文章

  1. iOS中使用block进行网络请求回调

    iOS中使用block进行网络请求回调 HttpRequest.h // // HttpRequest.h // UseBlockCallBack // // Created by Michael o ...

  2. iOS中使用RSA对数据进行加密解密

    RSA算法是一种非对称加密算法,常被用于加密数据传输.如果配合上数字摘要算法, 也可以用于文件签名. 本文将讨论如何在iOS中使用RSA传输加密数据. 本文环境 mac os openssl-1.0. ...

  3. IOS开发数据存储篇—IOS中的几种数据存储方式

    IOS开发数据存储篇—IOS中的几种数据存储方式 发表于2016/4/5 21:02:09  421人阅读 分类: 数据存储 在项目开发当中,我们经常会对一些数据进行本地缓存处理.离线缓存的数据一般都 ...

  4. 【原】iOS学习39网络之数据请求

    1. HTTP和HTTPS协议 1> URL URL全称是Uniform Resource Locator(统一资源定位符)通过1个URL,能找到互联网上唯一的1个资源 URL就是资源的地址.位 ...

  5. 安卓中使用OkHttp发送数据请求的两种方式(同、异步的GET、POST) 示例-- Android基础

    1.首先看一下最终效果的截图,看看是不是你想要的,这个年代大家都很忙,开门见山很重要! 简要说下,点击不同按钮可以实现通过不同的方式发送OkHttp请求,并返回数据,这里请求的是网页,所以返回的都是些 ...

  6. iOS中4种判断网络请求的方式(系统状态栏、AFNetworking、Reachability、自定义)

    iOS 实时判断网络状态 方法一:利用系统状态栏判断网络状态 // 状态栏是由当前app控制的,首先获取当前app UIApplication *app = [UIApplication shared ...

  7. nodejs 中 接受前端的数据请求的处理

    前台 ---->  后台 后台要接受 前台的数据,只能通过 http 但是 前台接受 后台的数据有  from   ajax    jsonp nodejs 给我们提供了模块 url 模块,可以 ...

  8. iOS中去除重复的数据

    本人只用了其中一个功能: 需求:一个已知数组arr,判断一个新字符str是否已经存在于arr中,如果不存在,则存入数组arr中 //去重 if (![arr containsObject:str]) ...

  9. 对比iOS中的四种数据存储

    来自于大牛的文章给大家分享下 :http://www.infoq.com/cn/articles/data-storage-in-ios/

随机推荐

  1. easing--缓动函数--贝塞尔函数--圆盘转动抽奖应用

    http://gsgd.co.uk/sandbox/jquery/easing/jquery.easing.1.3.js http://www.robertpenner.com/easing/penn ...

  2. JS的事件模型

    之前对事件模型还是比较清楚的,许多概念都清晰映射在脑海中.工作之后,一方面使用的局限性,二是习惯于用框架中的各种事件监听方式,简单即方便,久而久之,事件的一些概念开始淡出记忆中,就像我现在已经开始淡忘 ...

  3. JS中数组和字符串的方法大全

    数组的方法很多,ECMScript5又提供了好几种方法.有空把之前的云上的笔记整理了一下,方便自己以后查找使用. 一.ECMScript 3的Array.prototype中定义的方法 1.join( ...

  4. 网络不能上网但能ping通处理

    同事电脑不能上网,经过检查可以排除网线和网络问题,默认网关以及网页地址都能ping通,从网上搜索说是LSP问题,但是根据其操作方式修复,还是无效. 最后,不知道怎么捣鼓的,问题解决了. 操作流程: 1 ...

  5. c++ Struct和Class的区别

    C++中的struct对C中的struct进行了扩充,它已经不再只是一个包含不同数据类型的数据结构了,它已经获取了太多的功能.struct能包含成员函数吗? 能!struct能继承吗? 能!!stru ...

  6. 存出和载入Docker镜像

    存出镜像 如果要导出镜像到本地文件,可以使用 docker save 命令. $ sudo docker images REPOSITORY TAG IMAGE ID CREATED VIRTUAL ...

  7. Jmeter(六)_前置处理器

     BeanShell PreProcessor  使用BeanShell在请求进行之前进行操作.语法使用与BeanShell Sampler是一样的.但可使用的内置变量稍有不同 参考示例 Jmeter ...

  8. md编辑器测试

    markdown 这是一个代码 print

  9. 20160210.CCPP体系详解(0020天)

    程序片段(01):01.二级指针.c 内容概要:二级指针 #include <stdio.h> #include <stdlib.h> //01.二级指针: // 1.使用场景 ...

  10. Programming In Scala笔记-第十五章、Case Classes和模式匹配

    本章主要分析case classes和模式匹配(pattern matching). 一.简单例子 接下来首先以一个包含case classes和模式匹配的例子来展开本章内容. 下面的例子中将模拟实现 ...