AFNetworking之前因后果

        应一些朋友的建议,这篇文章主要介绍一些AFNetworking的详细使用。做iOS开发的童鞋应该没有不知道AFNetworking,它可以说是目前最好用的开源网络封装框架。本人也是从2.0一直到最新的3.0都有过使用,也研读了源代码,虽然没有完全参透,但是里面的实现细节确实让我学了很多。基于这个框架,很多app又做了二次封装,比如唐巧的猿题库,我也看过他们的源码,写的很不错。对于一般的app,没有必要封装的很高端,可以根据实际情况适当做封装即可。

        有些人可能做UI或者其他的比较多,对网络没有多少接触,下面我结合官方文档,教大家一步一步使用。
        首先,我先从2.x说起,根据我的调查,目前80%以上的都是在使用2.x。但随着苹果2013  WWDC 上推出的NSURLSession,AFNetworking也在3.0上废弃了以NSURLConnection为底层的传输框架。AFNetworking 1.0建立在NSURLConnection的基础API之上,AFNetworking 2.0开始使用NSURLConnection的基础API ,以及较新基于NSURLSession的API的选项。 AFNetworking 3.0现已完全基于NSURLSession的API,这降低了维护的负担,同时支持苹果增强关于NSURLSession提供的任何额外功能。

        在2.x中,一般的请求方式为:

       

AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
[manager GET:@"请求的url" parameters:nil success:^(AFHTTPRequestOperation *operation, id responseObject) {
        NSLog(@"成功");
} failure:^(AFHTTPRequestOperation *operation, NSError*error) {
        NSLog(@"失败");
}];

 

AFNetworking也包括post请求等,使用方法与上面类似。当然如果你需要更加抽象的封装,比如,所有方法都通过一个入口,可以使用AFHTTPRequestOperation类。在一些大公司或者大项目中,我们一般将post和get进行统一封装,通过NSURLRequest设置post/get方式,然后通过 AFHTTPRequestOperation获得请求,多个请求[[NSOperationQueue mainQueue] addOperation:op],添加到队列,方便管理。以下为其中的类似用法:

NSURL *URL = [NSURL URLWithString:@"http://example.com "];
NSURLRequest *request = [NSURLRequest requestWithURL:URL];
AFHTTPRequestOperation *op = [[AFHTTPRequestOperation alloc] initWithRequest:request];
op.responseSerializer = [AFHTTPResponseSerializer serializer];
[op setCompletionBlockWithSuccess:^(AFHTTPRequestOperation *operation, id responseObject) {
NSLog(@"JSON: %@", responseObject);
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
NSLog(@"Error: %@", error);
}];
[[NSOperationQueue mainQueue] addOperation:op];

在此,需要告诫大家,根据app后台的不同,responseSerializer设置的不一样,但是一般情况下都是需要设置的,否则会返回错误,类似context/text类似的问题。

而在3.0中,AFNetworking舍弃了AFHTTPRequestOperationManager 和AFHTTPRequestOperation ,主打AFURLSessionManager 和AFHTTPSessionManager 。使用方法如下:

NSURLSessionConfiguration *configuration = [NSURLSessionConfiguration defaultSessionConfiguration];
AFURLSessionManager *manager = [[AFURLSessionManager alloc] initWithSessionConfiguration:configuration];
NSURL *URL = [NSURL URLWithString:@"http://example.com/upload"];
NSURLRequest *request = [NSURLRequest requestWithURL:URL];
NSURLSessionDataTask *dataTask = [manager dataTaskWithRequest:request completionHandler:^(NSURLResponse *response, id responseObject, NSError *error) {
if (error) {
NSLog(@"Error: %@", error);
} else {
NSLog(@"%@ %@", response, responseObject);
}
}];
[dataTask resume];

当然也可以做进一步的封装,AFURLSessionManager提供了包括get、post、delete等方法,我们可以将这些方法通过一个入口导入。今天介绍的属于基本的使用方法,真正的项目开发中,网络模块经常需要进行二次封装,一个好的封装可以做到与UI层完全隔离,对外只暴露参数传入,其他的,比如超时,url设置等等全部内部实现,做到解耦。如果大家有什么问题,可以给我留言,本人也计划开源自己的一套网络封装。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

充电实践

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值