本文将从最简单的GET请求方法的使用入手,由表及里,逐步探究AFNetworking如何封装处理原生的网络请求。
一、AFNetworking的简单使用
-(void)getDemo{
AFHTTPSessionManager *manager =[AFHTTPSessionManager manager];
NSDictionary *dict = @{
@"username":@"testPara",
@"pwd":@"testPara"
};
NSDictionary *headersDict = @{
@"Accept":@"text/html",
@"Connection":@"keep-alive"
};
[manager GET:@"https://www.afntest:8010/test" parameters:dict headers:headersDict progress:^(NSProgress * _Nonnull downloadProgress) {
} success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
}];
}
Post、Put、Delete 与此Get类似
3.1 NSURLSessionTask包括三种Task类型,
分别为:
- NSURLSessionDataTask
- NSURLSessionDownLoadTask
- NSURLSessionUploadTask
3.2 网络请求的过程:
创建NSURLSessionConfig对象–用创建的config对象配置初始化NSURLSession–创建NSURLSessionTask对象并resume执行,用delegate或者block回调返回数据。
AFURLSessionManager封装了上述网络交互功能
AFURLSessionManager请求过程
1.初始化AFURLSessionManager。
2.获取AFURLSessionManager的Task对象
3.启动Task
3.3 AFNetworking由五个模块组成:
NSURLSession:网络通信模块(核心模块) 对应 AFNetworking中的
AFURLSessionManager和对HTTP协议进行特化处理的AFHTTPSessionManager,AFHTTPSessionManager是继承于AFURLSessionmanager的
Security:网络通讯安全策略模块 对应 AFSecurityPolicy
Reachability:网络状态监听模块 对应AFNetworkReachabilityManager
Seriaalization:网络通信信息序列化、反序列化模块 对应 AFURLResponseSerialization
UIKit:对于IOSUIKit的扩展库
NSURLSession
NSURLSessionConfiguation
NSURLSessionTask
初始化Session时未指定delegate的,通过block回调返回数据。