封装学无止境

高仿映客之四聊聊网络请求框架的那些事

2017-05-04  本文已影响80人  摸着石头过河_崖边树

前言####

各位同路人,小编首先声明本文不是讲什么AFN或者ASI什么的,而是借助于这些网络请求框架(如:AFNetworing)来封装我们自己项目的网络请求框架。
为什么要封装自己项目的网络请求框架呢?(以AFNetworing为例)
1、假如我们一直用的是AFNetworing,假设有一天AFNetworing不能用了,那么我们的项目就要改改改,麻烦并且琐碎;
2、AFN网络请求传入的参数是字典,得到的响应一般情况的也是JSON(可以设置),但是我们是面向对象开发,不是面向字典开发,所以最好是都转化为模型
3、返回错误码有时需要统一处理等

映客源码下载地址:高仿映客项目源码
映客系列详细解说目录:映客系列详细解说目录

封装AFNetworing的步骤#####

第一步
找到一个合适的解析框架(比如Mantle、MJExtension,本文采用Mantle),并且封装为一个解析模型BaseModel

/**
  *  模型转化为字典
  */
- (NSDictionary *)modelToDictionary;
/**
 *  字典转化模型 (属性值一一对应)
 */
+ (NSDictionary *)JSONKeyPathsByPropertyKey;

第二步
封装三个基类模型BaseHttpModel(响应数据模型)、BaseResponseModel(响应模型)、BaseResquestModel(数据请求模型),这几个基类模型都继承于BaseModel
BaseResquestModel:请求模型包括请求URL、网络请求模型参数转化为字典参数功能

BaseResponseModel:响应模型一般包括code、data、message 字段响应(具体于服务器定义API文档)

BaseHttpModel:响应的数据模型,具体是响应BaseResponseModel里面的data字段(具体可以和服务端定义)

第三步:
封装请求工具类,具体可以包括功能和可以配置的参数,具体实现可以下载demo,查看.m文件

//数据解析类型
typedef NS_ENUM(NSInteger,NetWorkResponseDataType)
{
  NetWorkResponseDataType_JSON = 1,  //JSON类型解析
  NetWorkResponseDataType_XML = 2,   //XML类型解析
  NetWorkResponseDataType_Default = NetWorkResponseDataType_JSON,
};
//结果block
typedef void(^sucessResponseBlock)(id response);
typedef void(^failResponseBlock)(NSError *error);
@interface NetWorkResquestTool : NSObject
 /**
  *  请求超时时间,默认10s
  */
@property (nonatomic, assign) NSTimeInterval timeOut;
/**
  *  响应回调队列,默认主队列
  */
 @property (nonatomic, strong) dispatch_queue_t responseQueue;
/**
 *  解析的数据类型,默认是 NetWorkResponseDataType_Default
*/
 @property (nonatomic, assign) NetWorkResponseDataType responseDataType;
/**
  *  统一的默认请求头字典
  */
@property (nonatomic, strong) NSMutableDictionary *resquestDefaultHeadDict;
/**
  *  请求参数模型
  */
@property (nonatomic, strong,readonly) BaseResquestModel *resquestModel;
/**
  *  请求响应模型
  */
 @property (nonatomic, strong,readonly)  BaseResponseModel *responseModel;
#pragma mark - method
/**
  *  get请求
  *
  *  @param requestModel  请求模型
  *  @param responseModel 响应模型
  *  @param sucessBlock   请求成功回调
  *  @param failBlock     请求失败回调
  *
  *  @return
  */
- (NSURLSessionDataTask *)httpGetWithModel:(BaseResquestModel *)requestModel
                         ResponseClass:(Class)responseClass
                        sucessResponse:(sucessResponseBlock)sucessBlock
                          failResponse:(failResponseBlock)failBlock;
/**
  *  Post请求
  *
  *  @param requestModel  请求模型
  *  @param responseModel 响应模型
  *  @param sucessBlock   请求成功回调
  *  @param failBlock     请求失败回调
  *
  *  @return
  */
- (NSURLSessionDataTask *)httpPostWithModel:(BaseResquestModel *)requestModel
                         ResponseClass:(Class)responseClass
                        sucessResponse:(sucessResponseBlock)sucessBlock
                          failResponse:(failResponseBlock)failBlock;

第四步
打造我们所要用到的请求类BaseHttpDataManger

@interface BaseHttpDataManger : BaseDataManger
 /**
  *  发送给请求
  *
  *  @param requestModel  请求模型
  *  @param responseModel 响应模型
  *  @param sucessBlock   成功
  *  @param failBlock     失败
  *
  *  @return 
  */
 - (NSURLSessionDataTask *)sendGetWithModel:(BaseResquestModel *)requestModel
                         ResponseClass:(Class)responseClass
                        sucessResponse:(sucessResponseBlock)sucessBlock
                          failResponse:(failResponseBlock)failBlock;
@end

第五步
封装自己的错误管理类,用来处理返回的错误码信息

映客源码下载地址:高仿映客项目源码
映客系列详细解说目录:映客系列详细解说目录

上一篇 下一篇

猜你喜欢

热点阅读