iOS专攻资源__网络专题iOS1收藏家-源码阅读

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

2017-03-09  本文已影响588人  RubyAhooo
YTKNetwork 源码阅读(一)-整体框架

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

  1. YTKNetwork 是基于 AFNetworking 封装的,提供了一些更高级的功能。
  1. YTKNetwork 的封装运用了 command 设计模式,有如下几个好处:
  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请求的完整历程

上一篇下一篇

猜你喜欢

热点阅读