IOS 常用网络 框架

IOS 一共有3种通讯框架,ASIHttpRequest,AFNetWorking,MKNetWork。

AFNetworking        https://github.com/AFNetworking/AFNetworking/

ASIHTTPRequest    文档: http://allseeing-i.com/ASIHTTPRequest/

                            下载:http://github.com/pokeb/asi-http-request/tarball/master

MKNetworkKit : 已经支持ios5

                             文档: http://blog.mugunthkumar.com/products/ios-framework-introducing-mknetworkkit/

                             下载:https://github.com/AFNetworking/AFNetworking/

 

其中 ASIHttpRequest比较臃肿,就是一个对CFNetwork API进行了封装,并且使用起来非常简单的一套API,用Objective-C编写,可以很好的应用在Mac OS X系统和iOS平台的应用程序中。ASIHTTPRequest适用于基本的HTTP请求,和基于REST的服务之间的交互。目前已经停止维护,基于代理的请求库,不建议使用。它没有对64位还有新api的处理

ASIHTTPRequest 依赖于以下5个框架或库:
CFNetwork, SystemConfiguration, MobileCoreServices,CoreGraphics和 libz1.2.3。
依次将上述库和框架添加到 target 的 Linked Libraries 中。
一、简单的同步请求示例
新建 iOS 项目,加入必需的源文件和 Linked Libraries。
往 MainWindow.xib 中添加一个 UIView和一个 UIButton,在 delegate 中添加相应的出口并在IB中进行连接。
编写按钮的Touch up inside代码,并连接到UIButton:
-(IBAction)goURL{
NSURL*url = [NSURLURLWithString:@"http://localhost/interface/GetDept"];
// 构造ASIHTTPRequest 对象
ASIHTTPRequest*request = [ASIHTTPRequestrequestWithURL:url];
// 开始同步请求
[request startSynchronous];
NSError*error = [requesterror];
assert(!error);
// 如果请求成功,返回Response
NSString*response = [requestresponseString];
NSLog(@"%@",response);
}
别忘了在适当的地方导入ASIHTTPRequest:#import"ASIHTTPRequest.h"
分别保存IB和Xcode中所做的更改,⌘+B编译。
二、简单的异步请求示例
将上述代码修改为:
-(IBAction)goURL{
NSURL*url = [NSURLURLWithString:@"http://localhost/interface/GetDept"];
ASIHTTPRequest*request = [ASIHTTPRequestrequestWithURL:url];
// 设定委托,委托自己实现异步请求方法
[request setDelegate:self];
// 开始异步请求
[request startAsynchronous];
}
并实现一系列委托方法:
// 请求结束,获取Response 数据
- (void)requestFinished:(ASIHTTPRequest*)request
{
NSString*responseString = [requestresponseString];// 对于2进制数据,使用:NSData *responseData = [request responseData];
NSLog(@"%@",responseString);
button.enabled=YES;
}
// 请求失败,获取error
- (void)requestFailed:(ASIHTTPRequest*)request
{
NSError*error = [requesterror];
NSLog(@"%@",error.userInfo);
button.enabled=YES;
}
从OS X 10.6及iOS 4.0起,支持块语法,你也可以使用块语法调用ASIHTTPRequest:
-(IBAction)goURL{
NSURL*url = [NSURLURLWithString:@"http://localhost/interface/GetDept"];
__blockASIHTTPRequest*request = [ASIHTTPRequestrequestWithURL:url];

// ASIHTTPRequest支持iOS 4.0的块语法,你可以把委托方法定义到块中
[request setCompletionBlock:^{
// 请求响应结束,返回responseString
NSString*responseString = [requestresponseString];//对于2进制数据,使用NSData返回NSData *responseData = [request responseData];
NSLog(@"%@",responseString);
}];
[request setFailedBlock:^{
//请求响应失败,返回错误信息
NSError*error = [requesterror];
NSLog(@"error:%@",[erroruserInfo]);
}];
[request startAsynchronous];
}

 

 

AFNetWorking, 基于block的方法。现在有两个主流版本 1.x版本与2.x版本,功能比较齐全,其中2.0版本还增加了ios7中NSUrlconnect 新的网络连接API

MKNetWork,同样是基于block的处理方法,比较轻量级,使用了operation queue。如果使用少量的http借口推荐使用

 

MKNetWork和AFNektwork感觉比较轻量级,本人推荐MKNetWork。MKNetworkKithttps://github.com/MugunthKumar/MKNetworkKit

 

MKNetWorkKit使用方法

MKNetworkKit 是一个使用十分方便,功能又十分强大、完整的iOS网络编程代码库。它只有两个类, 它的目标是使用像AFNetworking这么简单,而功能像ASIHTTPRequest(已经停止维护)那么强大。它除了拥有AFNetworking和ASIHTTPRequest所有功能以外,还有一些新特色,包括:


1、高度的轻量级,仅仅只有2个主类

2、自主操作多个网络请求

3、更加准确的显示网络活动指标

4、自动设置网络速度,实现自动的2G、3G、wifi切换

5、自动缓冲技术的完美应用,实现网络操作记忆功能,当你掉线了又上线后,会继续执行未完成的网络请求

6、可以实现网络请求的暂停功能

7、准确无误的成功执行一次网络请求,摒弃后台的多次请求浪费

8、支持图片缓冲

9、支持ARC机制

10、在整个app中可以只用一个队列(queue),队列的大小可以自动调整


MKNetworkKit的部署:

下载地址: https://github.com/MugunthKumar/MKNetworkKit/

将下载包中的MKNetWorkKit 文件夹拖到你新建的工程中。添加:SystemConfiguration.framework,CFNetwork.framework,Security.framework和ImageIO.framework

目前网上的介绍全都是旧版的MKNetworkKit, 新版的MKNetworkKit需要ImageIO.framework, 否则会报错.

运行Demo的时候, 需要打开最外层的 "MKNetworkKit.xcworkspace" 运行, 直接打开 demo 文件夹下的运行会报错. 同样也要手动加上 ImageIO.framework .

GET请求:

-(void)loadGet{

   MKNetworkEngine *engine = [[MKNetworkEnginealloc]initWithHostName:@"www.***.net"customHeaderFields:nil];

   MKNetworkOperation *op = [engineoperationWithPath:@"json/conn.asp?id=235"params:nilhttpMethod:@"GET"];

    [opaddCompletionHandler:^(MKNetworkOperation *completedOperation) {

       NSLog(@"%@",[completedOperationresponseString]);

    } errorHandler:^(MKNetworkOperation *completedOperation,NSError *error) {

       

    }];

   

    [engineenqueueOperation:op];

}


POST请求:


-(void)loadPost{

   MKNetworkEngine *engine = [[MKNetworkEnginealloc]initWithHostName:@"192.168.2.176:9502/api"customHeaderFields:nil];

   NSMutableDictionary *dic = [[NSMutableDictionaryalloc]init];

    [dicsetValue:@"admin"forKey:@"username"];

    [dicsetValue:@"123"forKey:@"password"];

   

   MKNetworkOperation *op = [engineoperationWithPath:@"user.do"params:dichttpMethod:@"POST"];

   

    [opaddCompletionHandler:^(MKNetworkOperation *completedOperation) {

       NSLog(@"%@",[completedOperationresponseString]);

    } errorHandler:^(MKNetworkOperation *completedOperation,NSError *error) {

       

    }];


    [engineenqueueOperation:op];

}


注意:


1. HostName不需要加"http://", 程序会自动添加, 主机要指向一个目录, 不可以是一个具体文件, 如上类不可以是"www.***.net/json/conn.asp"


2. 最新版的MKNetworkKit与目前网上介绍的版本不同, 方法也发生变化,类如


[op onCompletion:^(MKNetworkOperation *completedOperation) {

        <#code#>

    } onError:^(NSError *error) {

        <#code#>

    }];


已经更新为

[op addCompletionHandler:^(MKNetworkOperation *completedOperation) {

        <#code#>

    } errorHandler:^(MKNetworkOperation *completedOperation, NSError *error) {

        <#code#>

    }];

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值