前言####
各位同路人,小编首先声明本文不是讲什么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
第五步
封装自己的错误管理类,用来处理返回的错误码信息
映客源码下载地址:高仿映客项目源码
映客系列详细解说目录:映客系列详细解说目录