AFNetworking源码阅读笔记(三)

二、Serialization的AFURLResponseSerialization部分

AFHTTPResponseSerializer是反序列化器,主要功能是对返回的参数进行反序列化。

在第一篇分析AFURLSessionManager中分析过,如果网络请求返回成功将这样对返回的参数进行反序列化处理。

本篇就又这个入口开始分析反序列化器是如何对返回的参数进行处理的。

在此之前先分析一下反序列化器manager.responseSerializer的初始化方法:

AFNetworking源码阅读笔记(三)_第1张图片

可看出在初始化方法中设置了self.acceptableStatusCodesself.acceptableContentTypes这两个属性。self.acceptableStatusCodes为可接受的HTTP status code的集合,self.acceptableContentTypes为可接受的Content-Type集合(即请求头中设置的Content-Type)。

下面具体分析整个对返回参数的反序列化过程:

AFNetworking源码阅读笔记(三)_第2张图片
AFNetworking源码阅读笔记(三)_第3张图片
AFNetworking源码阅读笔记(三)_第4张图片
AFNetworking源码阅读笔记(三)_第5张图片

首先注意这个方法声明:

error参数用的是两个*的指针,目的是方法结束要返回这个error(由于OC方法只能有一个返回参数,所以要使用*error指针的指针来作为参数,参看详情)。

将这个方法折叠可得:

AFNetworking源码阅读笔记(三)_第6张图片

如果response为空,反而返回的responseIsValid反而是YES。但是从调用[self validateResponse:(NSHTTPURLResponse*)responsedata:dataerror:error]来看,这个返回参数似乎不重要也很少用到。

展开来看:

AFNetworking源码阅读笔记(三)_第7张图片

首先看一下这个外层的判断条件,self.acceptableContentTypes不为空,self.acceptableContentTypes不包含[response MIMEType][response MIMEType]为空和[data length] ==0不同时存在且[response MIMEType]不为空,当这三个条件都满足时,进入判断,接着分析:

由以下可知:

AFNetworking源码阅读笔记(三)_第8张图片

继续看满足条件下的代码:

AFNetworking源码阅读笔记(三)_第9张图片

配置一个字典mutableUserInfo,里边包含[response MIMEType][response URL]response信息。

继续:

AFNetworking源码阅读笔记(三)_第10张图片

如果data不为空,也将data信息添加到mutableUserInfo中。

根据mutableUserInfo构造validationError,设置codeAFURLResponseSerializationErrorDomain

具体构造函数为:

AFNetworking源码阅读笔记(三)_第11张图片

继续看接下来的判断分支:

AFNetworking源码阅读笔记(三)_第12张图片

如果self.acceptableStatusCodes不为空,self.acceptableStatusCodes包含response.statusCode[response URL]不为空,这三个条件都满足时,进入分支,和上一个分支主体类似,也是构造具体的validationError

整体来看,如果进入这两个小分支都会设置responseIsValid =NO,否则responseIsValid还是YES

最后:

AFNetworking源码阅读笔记(三)_第13张图片

如果responseIsValidNO时,将*validationError赋予传进来的error

返回到入口这里

AFNetworking源码阅读笔记(三)_第14张图片

可知这个方法主要是判断满足responseIsValid的条件,如果不满足设置其error,在这里提现了responseIsValid的作用,并没有对data进行具体处理。

又这个方法的调用

可知responseObject是NSData*类型,再回到请求完成的调用

是将NSData*类型的返回参数直接返回,在AFNetworking的范围内并没有处理。所以这种情况下是框架使用者来对responseObject做进一步处理,一般情况下将其转化为NSString*类型,再进行json解析,都可用系统方法实现。

最后看一下AFURLResponseSerialization的整体面貌:

和AFURLRequestSerialization类似,入口方法其实也是一个协议方法:

AFNetworking源码阅读笔记(三)_第15张图片

AFHTTPResponseSerialize遵守这个协议,实现了这个方法,另外有

这些子类,主要是分别实现了

这个属性,表示可以接收具体的Content-Type。以及别的一些特性。

特别提一点

AFNetworking源码阅读笔记(三)_第16张图片

AFHTTPSessionManager默认的初始化方法中实现的是AFJSONResponseSerializer

你可能感兴趣的:(AFNetworking源码阅读笔记(三))