对比AFNetwork 3.x 与 AFNetwork 2.x
AFNetworking支持HTTP请求和基于REST的网络服务(包括GET、POST、 PUT以及DELETE等),支持ARC。AFNetworking项目中还包含一些列单元测试。
AFNetworking 2.0开始使用NSURLConnection的基础API ,以及较新基于NSURLSession的API的选项。 AFNetworking 3.0现已完全基于NSURLSession的API,删除了了对 NSURLConnection的封装内容
这是因为NSURLSession能够完全替代NSURLConnection,并且具有很多优点:
- 支持后台运行的网络任务
- 暂停、停止、重启网络任务,不需要自己封装NSOperation
- 支持断点续传,异步下载
- 支持上传,异步上传
- 获取下载、上传的进度
注意:
3.0版本最低支持版本是从iOS7
1.废弃的类
废弃对NSURLConnection的支持
被删除的类:
- AFURLConnectionOperation
- AFHTTPRequestOperation
- AFHTTPRequestOperationManager
用以替代的是下面的类:
- AFURLSessionManager
- AFHTTPSessionManager
进行修改的类:
- UIImageView+AFNetworking
- UIWebView+AFNetworking.h
- UIButton+AFNetworking.h
如果你之前的开发是基于AFHTTPRequestOperationManager的网络请求现在你应该转到AFHTTPSessionManager下去进行
UIKit的迁移
图片下载已经被重构,以遵循AlamofireImage架构与新的AFImageDownloader类。这个类的图片下载职责的代理人是UIButton与UIImageView的类目,并且提供了一些方法,在必要时可以自定义。类别中,下载远程图片的实际方法没有改变。
UIWebView的类目被重构为使用AFHTTPSessionManager作为其网络请求。
UIAlertView的类目被废弃
从AFNetworking 3.0后UIAlertView的类目因过时而被废弃。并没有提供UIAlertController类目的计划,因为这是应用程序应处理的逻辑,而不是这个库。
下面进行新旧对比:
AFNetwork 2.x
AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
//设置网络请求超时时间
[manager.requestSerializer willChangeValueForKey:@"timeoutInterval"];
manager.requestSerializer.timeoutInterval = 30.0f;
[manager.requestSerializer didChangeValueForKey:@"timeoutInterval"];
[manager.requestSerializer setValue:@"application/x-www-form-urlencoded;" forHTTPHeaderField:@"Content-Type"];
[self addHeaderParams:manager];
manager.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"application/json",@"text/html",nil];
[manager POST:self.requestURL
parameters:self.requestParams
success:^(AFHTTPRequestOperation *operation, id responseObject) {
(@"success-POST:%@",responseObject);
}
failure:^(AFHTTPRequestOperation *operation, NSError *error) {
DebugLog(@"failurePOST:%@",error.description)
}];
AFNetworking 3.x
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
[manager.requestSerializer willChangeValueForKey:@"timeoutInterval"];
manager.requestSerializer.timeoutInterval = 30.0f;//30.0f
[manager.requestSerializer didChangeValueForKey:@"timeoutInterval"];
[manager.requestSerializer setValue:@"application/x-www-form-urlencoded;" forHTTPHeaderField:@"Content-Type"];
[self addHeaderParams:manager];
manager.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"application/json",@"text/html",nil];
[manager POST:self.requestURL parameters:self.requestParams progress:nil success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
NSLog(@"success-POST:%@",responseObject);
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
}];
即:每次开启一个网络请求时,首先新建一个AFHTTPSessionManager,然后将相关的requestSerializer和reponseSerializer赋值;最后发起相应的GET/POST等请求。
如果是直接采用NSURLSession来请求网络,写法如下:
NSURLSession *session = [NSURLSession
sessionWithConfiguration:
[NSURLSessionConfiguration defaultSessionConfiguration]
delegate:nil
delegateQueue:[NSOperationQueue mainQueue]];
NSURLSessionDataTask *dataTask = [session dataTaskWithRequest:request
completionHandler:completionHandler];
[dataTask resume];
即:新建一个Session(多个请求要用共享的SessionManager/Session),然后新建task,激活task,完成网络请求。
共享原因:
共享的Session将会复用TCP的连接,而每次都新建Session的操作将导致每次的网络请求都开启一个TCP的三次握手,共享会提升网络速度
AFNetworking 3.x 提供的post方法:
[manager POST: parameters: constructingBodyWithBlock: progress: success: failure:]
[manager POST: parameters: progress: success: failure:]
不建议使用的方法:
[manager POST: parameters: success: failure:];
[manager POST: parameters: constructingBodyWithBlock: success: failure:]
2. AFNetworking缓存
AFNetworking实际上使用了两个独立的缓存机制:
(1)AFImagecache:一个提供图片内存缓存的类,2.x时继承自NSCache,3.x不再使用NSCache。AFImagecache3.x之前存在于UIImageView+AFNetwork,之后存在于AFAutoPurgingImageCache中。
(2)NSURLCache:仍使用原生缓存机制:NSURLCache。NSURLConnection’s默认的URL缓存机制,用于存储NSURLResponse对象:一个默认缓存在内存,通过配置可以缓存到磁盘的类。NSURLCache对每个NSURLRequest对象都会遵守缓存策略(NSURLRequestCachePolicy)。
注意:NSCache与NSURLCache没有任何关系
3.0之前的缓存方法:存在于AFURLConnectionOperation类文件中。
- (void)setCacheResponseBlock:(NSCachedURLResponse * (^)(NSURLConnection *connection, NSCachedURLResponse *cachedResponse))block;
3.0之后:在类AFURLSessionManager中
- (void)setDataTaskWillCacheResponseBlock:(nullable NSCachedURLResponse * (^)(NSURLSession *session, NSURLSessionDataTask *dataTask, NSCachedURLResponse *proposedResponse))block;
描述:
Sets a block to be executed to determine the caching behavior of a data task, as handled by the
NSURLSessionDataDelegate
methodURLSession:dataTask:willCacheResponse:completionHandler:
.
@param block A block object to be executed to determine the caching behavior of a data task. The block returns the response to cache, and takes three arguments: the session, the data task, and the proposed cached URL response.
*/
苹果系统缓存存储策略:
{
NSURLCacheStorageAllowed, //默认,可以存在内存(重启设备清除),可以存储磁盘(代码清除)
NSURLCacheStorageAllowedInMemoryOnly,
NSURLCacheStorageNotAllowed,
} NSURLCacheStoragePolicy;
请求缓存策略:
{
NSURLRequestUseProtocolCachePolicy = 0, //默认策略
NSURLRequestReloadIgnoringLocalCacheData = 1,//忽略本地缓存,从源加载
NSURLRequestReloadIgnoringLocalAndRemoteCacheData = 4, // 忽略本地&服务器缓存,从源加载
NSURLRequestReloadIgnoringCacheData = NSURLRequestReloadIgnoringLocalCacheData,
NSURLRequestReturnCacheDataElseLoad = 2, //先从缓存加载,如果没有缓存,从源加载
NSURLRequestReturnCacheDataDontLoad = 3, //离线模式,加载缓存数据(无论是否过期),不从源加载
NSURLRequestReloadRevalidatingCacheData = 5 // 存在的缓存数据先确认有效性,无效的话从源加载
};
typedef NSUInteger NSURLRequestCachePolicy;
清除所有的URL缓存Response:
[[NSURLCache sharedURLCache] removeAllCachedResponses];