美文网首页
AFNetwoking源码——基本架构

AFNetwoking源码——基本架构

作者: C9090 | 来源:发表于2017-08-07 16:58 被阅读0次

    2017-08-04iOS开发

    概述

    从上图可以发现,AFNetwoking框架是一个比较简洁的框架,主要分为了几个部分

    网络通信模块:NSURLSession

    网络状态监听模块:Reachability

    网络通信安全模块:Security

    网络通信序列化模块:Serialization

    对UIKit框架扩展部分:UIKit(以Catagory形式添加特性)

    在这几个模块中,AFNetworking的核心模块是通信模块,在通信模块中有两个类,AFHTTPSessionManager和AFURLSessionManager,其中前者继承于后者,是对HTTP的专一化封装处理。大家都知道AFNetworking 3.0其实只是对NSURLSession做了封装处理,那接下来,就从源码角度来解释这个事情,在这之前我们先来看看使用NSURLSession和使用AFNetworking做网络请求在实现过程中有什么区别

    使用区别

    使用NSURLSession进行网络请求

    NSMutableURLRequest *request = [[NSMutableURLRequest alloc] initWithURL:[[NSURL alloc] initWithString:@"https://www.nineteen.me"]];

    NSURLSession *session = [NSURLSession sharedSession];

    NSURLSessionDataTask *task = [session dataTaskWithRequest:request

    completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) {

    NSString *dataString = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];

    NSLog(@"%@", dataString);

    }];

    [task resume];

    2.使用AFHTTP

    AFHTTPSessionManager *manager = [[AFHTTPSessionManager alloc] initWithBaseURL:[[NSURL alloc] initWithString:@"http://www.nineteen.me"]];

    [manager GET:@"2017/07/24/iOS核心动画/" parameters:nil progress:nil

    success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {

    // Success

    } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {

    // error

    }];

    可以发现使用AFHTTPSessionManager进行网络请求大致分为了两步:

    创建一个AFHTTPSessionManager对象

    使用这个对象调用含有block的请求方法

    从调用上来看,AFNetworking的请求会更加易读和编写,接下来我们就看看这两部分在框架中是如何实现的

    内部实现

    AFHTTPSessionManager类的架构

    在方法列表中,大致分为两部分,第一部分是初始化方法

    类初始化

    对象初始化

    manager这个类初始化方法是很常用的,我们去看它的实现,发现它也是调用了自己的对象初始化方法

    + (instancetype)manager {

    return [[[self class] alloc] initWithBaseURL:nil];

    }

    那我们就先来研究一下第一个部分,初始化AFHTTPSessionManager的内部实现,我们首先来看看,初始化方法的函数调用栈

    - [AFHTTPSessionManager initWithBaseURL:]

    - [AFHTTPSessionManager initWithBaseURL:sessionConfiguration:]

    - [AFURLSessionManager initWithSessionConfiguration:] // #1

    - [NSURLSession sessionWithConfiguration:delegate:delegateQueue:] // #2

    - [AFJSONResponseSerializer serializer]

    - [AFSecurityPolicy defaultPolicy]

    - [AFNetworkReachabilityManager sharedManager]

    - [AFHTTPRequestSerializer serializer]

    - [AFJSONResponseSerializer serializer]

    #1:调用了父类AFURLSessionManager的初始化方法

    #2:调用了原生类NSURLSession的初始化方法

    从上面的函数调用栈可以发现,AFNetworking的内部实现到栈底仍然是操作了原生的NSURLSession,从根本上只是对原生的NSURLSession做了封装操作,封装了一些序列化、通信安全等策略,提供简洁的API,方便用户编码。

    了解了初始化之后,我们再来看看发送请求的内部实现,在这里就用

    - [AFHTTPSessionManager GET:parameters:process:success:failure:]

    - [AFHTTPSessionManager dataTaskWithHTTPMethod:parameters:uploadProgress:downloadProgress:success:failure:] // #1

    - [AFHTTPRequestSerializer requestWithMethod:URLString:parameters:error:] // 获得NSMutableURLRequest

    - [AFURLSessionManager dataTaskWithRequest:uploadProgress:downloadProgress:completionHandler:] //  #2

    - [NSURLSession dataTaskWithRequest:] // #3

    - [AFURLSessionManager addDelegateForDataTask:uploadProgress:downloadProgress:completionHandler:] // 添加代理

    - [AFURLSessionManagerTaskDelegate init]

    - [AFURLSessionManager setDelegate:forTask:]

    - [NSURLSessionDataTask resume]

    #1、#2、#3这三个方法得到的是同一个对象,来自#3的NSURLSessionDataTask对象

    从这里也能发现请求操作内部实现也是和原生NSURLSession操作一样,创建task,调用resume发送请求

    总结

    AFNetworking2.0和3.0区别很大,也是因为苹果废弃了NSURLConnection,而改用了NSURLSession,AFNetworking3.0实际上只是对NSURLSession所做的操作进行了高度封装,提供更加简洁的API供编码调用。

    相关文章

      网友评论

          本文标题:AFNetwoking源码——基本架构

          本文链接:https://www.haomeiwen.com/subject/gjyalxtx.html