MKNetWorkKit使用方法
2013-12-20 16:26
399 查看
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 = [[MKNetworkEngine alloc] initWithHostName:@"www.***.net" customHeaderFields:nil];
MKNetworkOperation *op = [engine operationWithPath:@"json/conn.asp?id=235" params:nil httpMethod:@"GET"];
[op addCompletionHandler:^(MKNetworkOperation *completedOperation) {
NSLog(@"%@",[completedOperation responseString]);
} errorHandler:^(MKNetworkOperation *completedOperation, NSError *error) {
}];
[engine enqueueOperation:op];
}
POST请求:
-(void)loadPost{
MKNetworkEngine *engine = [[MKNetworkEngine alloc] initWithHostName:@"192.168.2.176:9502/api" customHeaderFields:nil];
NSMutableDictionary *dic = [[NSMutableDictionary alloc] init];
[dic setValue:@"admin" forKey:@"username"];
[dic setValue:@"123" forKey:@"password"];
MKNetworkOperation *op = [engine operationWithPath:@"user.do" params:dic httpMethod:@"POST"];
[op addCompletionHandler:^(MKNetworkOperation *completedOperation) {
NSLog(@"%@",[completedOperation responseString]);
} errorHandler:^(MKNetworkOperation *completedOperation, NSError *error) {
}];
[engine enqueueOperation: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#>
}];
大家需要注意.
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 = [[MKNetworkEngine alloc] initWithHostName:@"www.***.net" customHeaderFields:nil];
MKNetworkOperation *op = [engine operationWithPath:@"json/conn.asp?id=235" params:nil httpMethod:@"GET"];
[op addCompletionHandler:^(MKNetworkOperation *completedOperation) {
NSLog(@"%@",[completedOperation responseString]);
} errorHandler:^(MKNetworkOperation *completedOperation, NSError *error) {
}];
[engine enqueueOperation:op];
}
POST请求:
-(void)loadPost{
MKNetworkEngine *engine = [[MKNetworkEngine alloc] initWithHostName:@"192.168.2.176:9502/api" customHeaderFields:nil];
NSMutableDictionary *dic = [[NSMutableDictionary alloc] init];
[dic setValue:@"admin" forKey:@"username"];
[dic setValue:@"123" forKey:@"password"];
MKNetworkOperation *op = [engine operationWithPath:@"user.do" params:dic httpMethod:@"POST"];
[op addCompletionHandler:^(MKNetworkOperation *completedOperation) {
NSLog(@"%@",[completedOperation responseString]);
} errorHandler:^(MKNetworkOperation *completedOperation, NSError *error) {
}];
[engine enqueueOperation: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#>
}];
大家需要注意.
相关文章推荐
- Socket 异步通信
- 节奏大师风光无限 陌陌劲舞团能否异中取利
- 避免文件被当做病毒而被查杀,将之添加到白名单
- struts1与struts2区别
- 正确处理下载文件时HTTP头的编码问题(Content-Disposition)
- pku openjudge 拓扑排序
- 批量rebuild索引
- AS3使用PrintJob实现单页或多页打印
- 完美数简介及算法分析
- MIPI 接口知识点
- LeetCode—LRU Cache解题报告
- 关机后鼠标指示灯还亮着
- 黑马程序员_java面向对象总结【1】(面向对象概述)
- 通过action 使用 request.getParameter
- VMWare在Windows 7上无法上网问题的解决方法
- Window 安全策略
- 红包地方
- Mysql -InnoDB- innodb_file_per_table
- 将字符串转化成数字
- VC 获取打印机与打印作业的状态