YTKNetwork 源码阅读(一)-整体框架

作者: RubyAhooo | 来源:发表于2017-03-09 18:07 被阅读588次
    YTKNetwork 源码阅读(一)-整体框架

    有 AFNetworking 了,为什么还要用 YTKNetwork ? (以下1、2条文字摘自 YTKNetwork 的 readme)

    1. YTKNetwork 是基于 AFNetworking 封装的,提供了一些更高级的功能。
    • 支持按时间缓存网络请求内容
    • 支持按版本号缓存网络请求内容
    • 支持统一设置服务器和 CDN 的地址
    • 支持检查返回 JSON 内容的合法性
    • 支持文件的断点续传
    • 支持 block 和 delegate 两种模式的回调方式
    • 支持批量的网络请求发送,并统一设置它们的回调(实现在 YTKBatchRequest 类中)
    • 支持方便地设置有相互依赖的网络请求的发送,例如:发送请求 A,根据请求 A 的结果,选择性的发送请求 B 和 C,再根据 B 和 C 的结果,选择性的发送请求 D。(实现在 YTKChainRequest 类中)
    • 支持网络请求 URL 的 filter,可以统一为网络请求加上一些参数,或者修改一些路径。
    • 定义了一套插件机制,可以很方便地为 YTKNetwork 增加功能。猿题库官方现在提供了一个插件,可以在某些网络请求发起时,在界面上显示“正在加载”的 HUD。
    1. YTKNetwork 的封装运用了 command 设计模式,有如下几个好处:
    • 将网络请求与具体的第三方库依赖隔离,方便以后更换底层的网络库。实际上 YTKNetwork 最初是基于 ASIHttpRequest 的,我们只花了两天,就很轻松地切换到了 AFNetworking。
    • 方便在基类中处理公共逻辑,例如猿题库的数据版本号信息就统一在基类中处理。
    • 方便在基类中处理缓存逻辑,以及其它一些公共逻辑。
    • 方便做对象的持久化。
    1. YTKNetwork 把每个请求都封装成对象,代码组织的时候可以把所有的请求类都放到一个目录底下,我个人是比较喜欢这种组织方式。

    说下 YTKNetwork 里面重要的几个类

    1. YTKNetworkConfig 存储一些全局的网络配置。比较重要的就是 baseUrl(根URL路径)、cdnUrl(CDN服务器路径)、urlFilters(在请求发送之前,附加到URL路径上的一些公共参数)。

    2. YTKRequest 相当于 command 设计模式中的 command。使用过程中,我们通过创建基于 YTKRequest 的网络请求类,重写一些父类的方法来访问后台。他是继承于 YTKBaseRequest。YTKBaseRequest 类提供了开始网络请求的便利方法。

       //YTKBaseRequest 类
      
       //  把一个请求加到队列里面,并且开始这个请求
       - (void)start; // -> 调用 YTKNetworkAgent 的 addRequest: 方法
      
       /// 把一个请求从请求队列里面移除掉,并且取消这个请求。   
       - (void)stop;  // -> 调用 YTKNetworkAgent 的 cancelRequest: 方法
      
       ///  便利请求方法,包含成功和失败的block回调.
       - (void)startWithCompletionBlockWithSuccess:(nullable YTKRequestCompletionBlock)success
                                   failure:(nullable YTKRequestCompletionBlock)failure;  // -> 调用 [self start] 并且设置成功和失败的两个回掉
      
    3. YTKNetworkAgent 类是一个单例,相当于 command 设计模式中的接收器,发出指令的对象和被调用的对象就是通过它来实现解耦的。网络请求的操作是在这里开始的。

       //YTKNetworkAgent 类
      
       ///  添加一个网络请求并开始
       - (void)addRequest:(YTKBaseRequest *)request;
       ///  取消之前添加的一个网络请求
       - (void)cancelRequest:(YTKBaseRequest *)request;
       ///  取消之前添加的所有网络请求
       - (void)cancelAllRequests;
      
    4. YTKNetworkPrivate 类包含了一个工具类和一些 extension

       //YTKNetworkUtils 
       // 验证json的有效性
       + (BOOL)validateJSON:(id)json withValidator:(id)jsonValidator;
       // 阻止 iTunes 在应用中保存数据
       + (void)addDoNotBackupAttribute:(NSString *)path;
       // 对字符串进行 md5 加密
       + (NSString *)md5StringFromString:(NSString *)string;
       // 获取 app 的版本号
       + (NSString *)appVersionString;
      
    5. YTKBatchRequest 用于方便的发送批量的请求。它是一个容器类,可以放置多个继承于 YTKRequest 的请求实例。

       // 通过一个请求数组创建一个 batch 请求
       - (instancetype)initWithRequestArray:(NSArray<YTKRequest *> *)requestArray;
       // 开始这个 batch 请求
        - (void)startWithCompletionBlockWithSuccess:(nullable void (^)(YTKBatchRequest *batchRequest))success
                                   failure:(nullable void (^)(YTKBatchRequest *batchRequest))failure;
      
    6. YTKChainRequest 用于管理相互之间有依赖的多个请求。

       // YTKChainRequest
       //添加一个请求并开始
       - (void)addRequest:(YTKBaseRequest *)request callback:(nullable YTKChainCallback)callback;
      
       // 官方示例: 
       - (void)sendChainRequest {
           // 创建一个注册的请求
           RegisterApi *reg = [[RegisterApi alloc] initWithUsername:@"username" password:@"password"]; 
           // 创建 chain 请求实例
           YTKChainRequest *chainReq = [[YTKChainRequest alloc] init];
           // 开始注册请求
           [chainReq addRequest:reg callback:^(YTKChainRequest *chainRequest, YTKBaseRequest *baseRequest) {
               RegisterApi *result = (RegisterApi *)baseRequest;
               NSString *userId = [result userId];
               //注册请求完成,开始获取个人信息的请求
               GetUserInfoApi *api = [[GetUserInfoApi alloc] initWithUserId:userId];
               [chainRequest addRequest:api callback:nil]; //这里仍然调用了 addRequest:callback: 方法,回调为nil
      
           }];
           chainReq.delegate = self;
           // start to send request
           [chainReq start];
       }
      
       // YTKChainRequestDelegate  代理
      
       // 所有 chain 请求完成的回调
       - (void)chainRequestFinished:(YTKChainRequest *)chainRequest;
      
       // 某个 chain 请求失败的回调
       - (void)chainRequestFailed:(YTKChainRequest *)chainRequest failedBaseRequest:(YTKBaseRequest*)request;
      

    YTKNetwork 源码阅读(二)-一次POST请求的完整历程

    相关文章

      网友评论

        本文标题:YTKNetwork 源码阅读(一)-整体框架

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