博客> AFN实现原理
AFN实现原理
2017-12-11 22:27 评论:0 阅读:287 ShanChengZhang
AFNetworking 实现原理

AFN的基本原理 (小小笔记)

AFN的六大模块 NSURLConnection,主要对NSURLConnection进行了进一步的封装,包含以下核心的类: AFURLConnectionOperation AFHTTPRequestOperationManager AFHTTPRequestOperation NSURLSession,主要对象NSURLSession对象进行了进一步的封装,包含以下核心的类: AFURLSessionManager AFHTTPSessionManager Reachability,提供了与网络状态相关的操作接口,包含以下核心的类: AFNetworkReachabilityManager Security,提供了与安全性相关的操作接口,包含以下核心的类: AFSecurityPolicy Serialization,提供了与解析数据相关的操作接口,包含以下核心的类: AFURLRequestSerialization AFURLResponseSerialization UIKit,提供了大量网络请求过程中与UI界面显示相关的操作接口,通常用于网络请求过程中提示,使用户交互更加友好,包含以下核心的分类/类: AFNetworkActivityIndicatorManager UIActivityIndicatorView+AFNetworking UIAlertView+AFNetworking UIButton+AFNetworking UIImageView+AFNetworking UIKit+AFNetworking UIProgressView+AFNetworking UIRefreshControl+AFNetworking UIWebView+AFNetworking AFURLSessionManager

创建任务的方法 普通任务

  • (NSURLSessionDataTask )dataTaskWithRequest:(NSURLRequest )request completionHandler:(void (^)(NSURLResponse response, id responseObject, NSError error))completionHandler /**
  • request:请求对象
  • completionHandler:请求完成调用的Block
    • response:服务器的响应信息
    • responseObject:服务器返回的数据
    • error:错误信息 */

上传任务(分别上传不同类型的文件)

// 1. 上传文件类型的数据

  • (NSURLSessionUploadTask )uploadTaskWithRequest:(NSURLRequest )request fromFile:(NSURL )fileURL progress:(NSProgress __autoreleasing )progress completionHandler:(void (^)(NSURLResponse response, id responseObject, NSError *error))completionHandler /**
  • fileURL:所要上传文件的路径 */

// 2. 上传NSData类型的数据

  • (NSURLSessionUploadTask )uploadTaskWithRequest:(NSURLRequest )request fromData:(NSData )bodyData progress:(NSProgress __autoreleasing )progress completionHandler:(void (^)(NSURLResponse response, id responseObject, NSError *error))completionHandler /**
  • bodyData:所要上传的文件数据 */

// 3. 上传流数据

  • (NSURLSessionUploadTask )uploadTaskWithStreamedRequest:(NSURLRequest )request progress:(NSProgress __autoreleasing )progress completionHandler:(void (^)(NSURLResponse response, id responseObject, NSError error))completionHandler /**
  • request:通过流数据初始化的请求对象 */

下载任务

// 1. 普通下载任务

  • (NSURLSessionDownloadTask )downloadTaskWithRequest:(NSURLRequest )request progress:(NSProgress __autoreleasing )progress destination:(NSURL (^)(NSURL targetPath, NSURLResponse response))destination completionHandler:(void (^)(NSURLResponse response, NSURL filePath, NSError error))completionHandler /**
  • progress:管理下载进度
  • destination:保存数据调用的Block
    • targetPath:数据的保存路径
    • 服务器的响应信息 */

// 2. 支持断点下载的下载任务

  • (NSURLSessionDownloadTask )downloadTaskWithResumeData:(NSData )resumeData progress:(NSProgress __autoreleasing )progress destination:(NSURL (^)(NSURL targetPath, NSURLResponse response))destination completionHandler:(void (^)(NSURLResponse response, NSURL filePath, NSError error))completionHandler /**
  • progress:管理下载进度
  • resumeData:断点下载时的断点信息 */

AFHTTPSessionManager 常用的属性 baseURL(NSURL ),用于监视网络可达性与创建请求对象 requestSerializer(AFHTTPRequestSerializer ),指定指定GET、HEAD与DELETE请求参数的解析格式 responseSerializer(AFHTTPResponseSerializer *),用于指定服务器返回数据的格式

常用方法 初始化

// 1. 通过工厂方法创建AFHTTPSessionManager对象

  • (instancetype)manager // 2. 通过构造方法创建AFHTTPSessionManager对象
  • (instancetype)initWithBaseURL:(NSURL *)url /**
  • 根据url初始化AFHTTPSessionManager对象 */
  • (instancetype)initWithBaseURL:(NSURL )url sessionConfiguration:(NSURLSessionConfiguration )configuration /**
  • 根据url与configuration初始化AFHTTPSessionManager对象 */

请求数据

// 1. GET请求

  • (NSURLSessionDataTask )GET:(NSString )URLString parameters:(id)parameters success:(void (^)(NSURLSessionDataTask task, id responseObject))success failure:(void (^)(NSURLSessionDataTask task, NSError *error))failure /**
  • URLString:请求路径
  • parameters:请求参数
  • success:请求成功时调用的Block
    • responseObject:服务器返回的数据
  • failure:请求失败时调用的Block
    • error:错误信息 */ // 2. POST请求
  • (NSURLSessionDataTask )POST:(NSString )URLString parameters:(id)parameters success:(void (^)(NSURLSessionDataTask task, id responseObject))success failure:(void (^)(NSURLSessionDataTask task, NSError *error))failure /**
  • 参数含义与GET请求相同 */
  • (NSURLSessionDataTask )POST:(NSString )URLString parameters:(id)parameters constructingBodyWithBlock:(void (^)(id formData))block success:(void (^)(NSURLSessionDataTask task, id responseObject))success failure:(void (^)(NSURLSessionDataTask task, NSError *error))failure /**
  • block:用于创建多个数据来源 */

使用AFN请求网络数据

请求数据(XML/JSON) 创建AFHTTPSessionManager对象

AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];

指定对服务器的返回数据格式

//以XML文档的形式返回数据 manager.responseSerializer = [AFXMLParserResponseSerializer serializer]; //以JSON形式返回数据 manager.responseSerializer = [AFJSONResponseSerializer serializer];

设置请求体(类型为XML或JSON)

// 请求体通常由服务器指定格式 NSDictionary *params = @{ @username : @账号, @pwd : @密码, @type : @XML/JSON };

发送请求

[manager GET:@请求路径 parameters:params success:^(NSURLSessionDataTask task, id responseObject) { //responseObject:服务器返回的数据 NSLog(@请求成功); } failure:^(NSURLSessionDataTask task, NSError *error) { //error:错误信息 NSLog(@请求失败); }];

上传数据 创建AFHTTPSessionManager对象

AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];

创建上传任务

/*基于NSURLConnection/ [manager POST:@请求路径 parameters:@{@用户名 : @密码 constructingBodyWithBlock:^(id formData) { //设置需要上传的文件 NSData data = [NSData dataWithContentsOfFile:@所要长传文件的路径]; [formData appendPartWithFileData:data name:@file fileName:@test.png mimeType:@image/png]; } success:^(NSURLSessionDataTask task, id responseObject) {
//上传成功 } failure:^(NSURLSessionDataTask task, NSError error) { //上传失败 }];

/*基于NSURLSession/ [manager uploadTaskWithRequest:request fromData:data progress:progress completionHandler:^(NSURLResponse response, id responseObject, NSError error) { //上传数据成功 }];

下载数据 创建AFHTTPSessionManager对象

AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];

创建下载任务

/*基于NSURLSession/ [manager downloadTaskWithRequest:request progress:progress destination:^NSURL (NSURL targetPath, NSURLResponse response) { // 存储下载数据是调用的Block } completionHandler:^(NSURLResponse response, NSURL filePath, NSError error) { //下载完成时调用的Block }]

收藏
0
sina weixin mail 回到顶部