本文将从最简单的get请求方法的使用入手,由表及里,逐步探究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类似
afnetworking的封装分为 task(任务) 和 request(请求) 等
这个方法在afhttprequestserializer.m里面
至此、request的封装初步完成
这个图也是sessionmanager与nsurlsessiontask的关联
nsurlsession由三个基本模块构成:
nsurlsession
nsurlsessionconfiguation
nsurlsessiontask
初始化session时未指定delegate的,通过block回调返回数据。
(只为展示类之间的关联关系,并没有给出每个类的所有属性和方法)
分别为:
创建nsurlsessionconfig对象–用创建的config对象配置初始化nsurlsession–创建nsurlsessiontask对象并resume执行,用delegate或者block回调返回数据。
afurlsessionmanager封装了上述网络交互功能
afurlsessionmanager请求过程
1.初始化afurlsessionmanager。
2.获取afurlsessionmanager的task对象
3.启动task
nsurlsession:网络通信模块(核心模块) 对应 afnetworking中的
afurlsessionmanager和对http协议进行特化处理的afhttpsessionmanager,afhttpsessionmanager是继承于afurlsessionmanager的
security:网络通讯安全策略模块 对应 afsecuritypolicy
reachability:网络状态监听模块 对应afnetworkreachabilitymanager
seriaalization:网络通信信息序列化、反序列化模块 对应 afurlresponseserialization
uikit:对于iosuikit的扩展库