Alamofire:response流程及序列化

前言:在Swift慢慢趋向于稳定且高效的时候,OC也随着时间一点点的消逝,曾经的诸多OC框架也都投向了Swift的怀抱,而Swift对于框架的提升也逐渐的展露头脚。

Alamofire作为AFNetworking的升级版,在网络请求的框架中有着非常众多的使用者,所以今天就来学习Alamofire框架中的response流程和常见的多表单上传。

response流程

response在Alamofire中扮演了什么角色?

response直译过来是反应、响应的。在普通网络请求中,我们是通过闭包或者代理方法来获得数据请求请求的,这里来看一段普通请求的代码。

这是一段最简单的请求,没有头文件的设置。在闭包中返回了data,response,error三个参数。那这里的response是什么呢?

这里通过打印可以看到NSHTTPURLResponse的类,其实主体就是两个字典,而NSHTTPURLResponse是继承自NSURLResponse的类,属性是来自于NSURLResponse。

response在这里是作为保存Url、请求的状态和请求的头信息存在的,那Alamofire是否是同样的作用呢?


AF和Session.default是同样的作用

追溯源码开始

这里直接创建了response,是一个DataResponse,那这个DataResponse是不是在闭包中获取到的呢,暂时还不得而知。这里先来看一下DataResponse是什么。

这是一个保存信息的结构体。什么方法也没有,声明了一堆的属性。回头看创建的response,此时是保存信息。

保存的是什么信息呢,这里self.request,self.response,self.data,self.metrics,以及result都是什么呢?这里的self 指向了DataRequest,同样来到DataRequest中

DataRequest类中只有一个data,来自于mutableData,其他的属性呢?看继承的关系,只能去DataRequest的父类中去寻找。在Request类中找到了其他的的属性。数据太多,这里就不截图了。可以看到一点的是,不管是data还是其他的属性都是在这里声明的。

看到这里似乎有一点明白了,response是一个响应的存储类,保存了我们的url,返回的data,以及error等属性。


再接着向下走

-> self.eventMonitor?.request(self, didParseResponse: response)

肯定是看最后一个request的方法

这个时候肯定是需要了解清楚这个eventMonitor是什么

源码中很清晰,这里是一个协议,定义了很多的方法。只需要找到是谁实现的这个协议就清楚了request方法究竟做了什么。


再次跳转,可以看到这个eventMonitor  被添加进入了一个monitors的数组中,这下就明白了,这个request的方法是监控回调的。

这里很清楚的看到并没有使用session的闭包请求,那么请求的回调一定是发生在代理中的。

最开始的ruqest方法已经开始了请求,那么就需要在URLSessionDataDelegate实现的代理中找到回调的方法

在这里我们就将请求到的数据写入了对应的response中去了。

当然在这里还没有结束->  self.responseSerializerDidComplete 这一句就是将闭包追加到请求的状态中。

当请求成功的时候将请求的状态修改为isFinished,然后调用对应外界的回调闭包,将请求的数据及请求的状态以及请求的参数打包整理好的response,通过闭包回调出去。

总结一下:Alamofire 采用了将请求和参数以及回调的闭包封装为成为一个新的DataResponse,然后通过监听URLSessionDataDelegate代理中回调的方法,获取到请求成功或失败的数据,再将其添加到DataResponse中,最后通过保存的闭包将其返回,完成一个闭包返回所有数据的功能。

你可能感兴趣的:(Alamofire:response流程及序列化)