第三方框架 | AFNetworking源码解析(2) 初始化

2018-08-17  本文已影响34人  UncleFool

类结构


今天主要对 AFNetworking 的初始化过程进行整理,首先看一下文件结构图,这里除 UIKit 部分一共包括6个类:AFHTTPSessionManagerAFURLSessionManagerAFSecurityPolicyAFURLRequestSerializationAFURLResponseSerializationAFNetworkReachabilityManager

文件结构

初始化



我们在初始化的地方设置断点,通过调用栈可以一步步观察到 AFHTTPSessionManager 对象的初始化过程。正如之前所提 AFHTTPSessionManager 继承自 AFURLSessionManager ,可以知道 initWithSessionConfiguration: 就是核心初始化方法。接下来我们看一下这个方法里面做了哪些事:
- (instancetype)initWithSessionConfiguration:(NSURLSessionConfiguration *)configuration {
    self = [super init];
    if (!self) {
        return nil;
    }
    // 初始化NSURLSessionConfiguration对象
    if (!configuration) {
        configuration = [NSURLSessionConfiguration defaultSessionConfiguration];
    }
    self.sessionConfiguration = configuration;

    // 初始化操作队列,并设置最大并发数为1
    self.operationQueue = [[NSOperationQueue alloc] init];
    self.operationQueue.maxConcurrentOperationCount = 1;

    // 使用NSURLSessionConfiguration对象和队列对象初始化NSURLSession对象,并设置代理
    self.session = [NSURLSession sessionWithConfiguration:self.sessionConfiguration delegate:self delegateQueue:self.operationQueue];

    // 初始化响应序列器,默认响应JSON数据
    self.responseSerializer = [AFJSONResponseSerializer serializer];

    // 初始化AFSecurityPolicy对象,负责证书安全认证
    self.securityPolicy = [AFSecurityPolicy defaultPolicy];

    // 初始化网络监测器,用于检测网络连接状态
#if !TARGET_OS_WATCH
    self.reachabilityManager = [AFNetworkReachabilityManager sharedManager];
#endif

    self.mutableTaskDelegatesKeyedByTaskIdentifier = [[NSMutableDictionary alloc] init];

    self.lock = [[NSLock alloc] init];
    self.lock.name = AFURLSessionManagerLockName;

    // 设置代理
    [self.session getTasksWithCompletionHandler:^(NSArray *dataTasks, NSArray *uploadTasks, NSArray *downloadTasks) {
        // 设置数据任务代理
        for (NSURLSessionDataTask *task in dataTasks) {
            [self addDelegateForDataTask:task uploadProgress:nil downloadProgress:nil completionHandler:nil];
        }
        // 设置上传任务代理
        for (NSURLSessionUploadTask *uploadTask in uploadTasks) {
            [self addDelegateForUploadTask:uploadTask progress:nil completionHandler:nil];
        }
        // 设置下载任务代理
        for (NSURLSessionDownloadTask *downloadTask in downloadTasks) {
            [self addDelegateForDownloadTask:downloadTask progress:nil destination:nil completionHandler:nil];
        }
    }];

    return self;
}

说明


NSURLSessionConfiguration

NSURLSessionConfiguration 对象定义了使用 NSURLSession 对象上传和下载数据时要使用的行为和策略。在上传或下载数据时,创建配置对象总是您必须采取的第一步。您可以使用该对象来配置超时值、缓存策略、连接需求和其他类型的信息,这些信息是您打算与 NSURLSession 对象一起使用的。

在使用 NSURLSessionConfiguration 对象初始化会话对象之前,适当地配置 NSURLSessionConfiguration 对象是非常重要的。会话对象复制您提供的配置设置并使用这些设置来配置会话。一旦配置好,会话对象就会忽略对 NSURLSessionConfiguration 对象所做的任何更改。如果需要修改传输策略,则必须更新会话配置对象并使用它创建新的 NSURLSession 对象。

AFJSONResponseSerializer

AFJSONResponseSerializerAFHTTPResponseSerializer 的子类,用来验证和解码 JSON 响应。默认情况下,AFJSONResponseSerializer 接受以下 MIME 类型,其中包括官方标准 application/json 以及其他常用类型:

在RFC 7159 - 8.1节中,它指出JSON文本需要用UTF-8、UTF-16或UTF-32编码,默认编码是UTF-8。NSJSONSerialization 提供了对规范中列出的所有编码的支持,并推荐使用UTF-8来提高效率。使用不支持的编码将导致序列化错误。有关详细信息,请参阅“NSJSONSerialization”文档。

总结


在该初始化方法中,它做了这么几件事:
(1)初始化会话配置(session configuration)默认为 defaultSessionConfiguration
(2)初始化队列,设置队列的最大并发数为1
(3)初始化会话(session),并将 session 的代理对象设置为 self(也就是当前 AFURLSessionManager 对象),并将代理队列设置为(2)中创建的队列。
(4)初始化响应序列化
(5)初始化安全认证
(6)初始化网络状态监控
(7)初始化保存 NSURLSessionDataTask 的字典(很重要)
(8)初始化线程锁(很重要)
(9)最后一大坨代码是为已经存在的 task 设置 delegate(也很重要)

上一篇下一篇

猜你喜欢

热点阅读