AFNetworking 框架小结 二(AFURLResponseSerialization)

2024-06-06 13:08

本文主要是介绍AFNetworking 框架小结 二(AFURLResponseSerialization),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

AFURLResponseSerialization

响应报文解析器

在 AFNetworking 网络框架中,为了方便处理网络返回的响应报文,特抽象出来一个响应报文解析器,其相关的类都在 AFURLResponseSerialization.h 文件中。相较于网络请求报文构造器,解析器要简单的多,其关键为抽象类 AFHTTPResponseSerializer 以及其遵循的 AFURLResponseSerialization 协议。

AFHTTPResponseSerializer

AFHTTPResponseSerializer 会对响应报文做一些基本的处理,所以自定义处理 HTTP 响应报文时,应扩展其子类以保证基本的报文处理得以进行,不过,该框架中提供的子类解析器已经满足了大部分需要。

在 AFHTTPResponseSerializer 类中定义了两个重要的属性和一个判断响应报文是否有效的方法。

@property (nonatomic, copy, nullable) NSIndexSet *acceptableStatusCodes;
@property (nonatomic, copy, nullable) NSSet <NSString *> *acceptableContentTypes;
  • acceptableStatusCodes 合法的报文状态码集合
  • acceptableContentTypes 合法的报文体数据类型集合

上述两个属性会在下面的方法中被用来判断响应报文是否是有效报文,当然,如果这两个属性为 nil ,那么便不会使用其进行判断。

- (BOOL)validateResponse:(nullable NSHTTPURLResponse *)responsedata:(nullable NSData *)dataerror:(NSError * _Nullable __autoreleasing *)error;

调用上面的方法,判断 response 的 MIMEType 属性值是否在 acceptableContentTypes 集合中,response 的 statusCode 属性值是否在 acceptableStatusCodes 范围内,并且 data 是否存在,如果校验不通过,相关的错误信息会保存在 error 中并返回 NO 。

在创建解析器时,可以调用类方法 serializer ,在该方法中,会初始化 acceptableStatusCodes 属性集合的范围为 200~300 ,而 acceptableContentTypes 会被置为 nil 。

AFURLResponseSerialization

该协议只提供了一个方法,用来解析响应报文中的数据,最后的返回值为解析后的数据。在自定义 AFHTTPResponseSerializer 的子类时,应该重写该协议方法,因为 AFHTTPResponseSerializer 类中并未对与报文相关的 data 数据进行额外的处理,而是直接返回了。

- (nullable id)responseObjectForResponse:(nullable NSURLResponse *)responsedata:(nullable NSData *)dataerror:(NSError * _Nullable __autoreleasing *)error NS_SWIFT_NOTHROW;

AFJSONResponseSerializer

AFJSONResponseSerializer 类重写了父类 AFHTTPResponseSerializer 中的实例创建方法和初始化方法,并提供了下面的类方法用于创建解析 JSON 数据的实例对象。

+ (instancetype)serializerWithReadingOptions:(NSJSONReadingOptions)readingOptions;

并且可以通过设置 removesKeysWithNullValues 属性值为 YES 来过滤为 NULL 的数据。

在创建 JSON 数据的解析器时,其初始化方法,会将有效的报文类型集合设置为 application/jsontext/jsontext/javascript ,如下:

self.acceptableContentTypes = [NSSet setWithObjects:@"application/json", @"text/json", @"text/javascript", nil];

这样在校验报文数据时,就会过滤掉非 JSON 格式的返回报文,然后使用 NSJSONSerialization 解析 JSON 数据得到相应的对象,如果需要移除为 NULL 的值,则会接着调用下面的函数。

static id AFJSONObjectByRemovingKeysWithNullValues(id JSONObject, NSJSONReadingOptions readingOptions)

AFXMLParserResponseSerializer

AFXMLParserResponseSerializer 同样是 AFHTTPResponseSerializer 的子类,只是其并未增加属性,只是重写了父类的方法。

在初始化方法中将 acceptableContentTypes 设置为 application/xmltext/xml 的集合。

在 AFURLResponseSerialization 协议的方法中,使用接收到的数据创建了一个 XML 数据解析器 NSXMLParser 并返回,进一步的解析则由用户负责。

AFXMLDocumentResponseSerializer

AFXMLDocumentResponseSerializer 与 AFXMLParserResponseSerializer 类似,有相同的报文类型集合,但是其重写的解析方法最后返回的是 NSXMLDocument 对象。

该解析器只适用于 Mac OS X 系统中

AFPropertyListResponseSerializer

AFPropertyListResponseSerializer 可以用来解析类型为 application/x-plist 的返回报文,在重写 AFURLResponseSerialization 中的方法时,会创建并返回一个 NSPropertyListSerialization 类实例对象。

AFImageResponseSerializer

AFImageResponseSerializer 用来解析请求到的图片数据,其默认支持的图片格式如下:

  • image/tiff
  • image/jpeg
  • image/gif
  • image/png
  • image/ico
  • image/x-icon
  • image/bmp
  • image/x-bmp
  • image/x-xbitmap
  • image/x-win-bitmap

在该子类中,声明了 imageScaleautomaticallyInflatesResponseImage 两个属性,前者指定图片的缩放值,默认为设备屏幕的缩放值。后者指明是否调用函数 AFInflatedImageFromResponseWithDataAtScale 对请求的图片的透明度信息进行填充,默认为 YES ,即进行填充。

在 AFInflatedImageFromResponseWithDataAtScale 函数中,只会对类型为 PNG 和 JPEG 类型的图片进行处理,并且图片如果是 JPEG 类型且其颜色空间为 kCGColorSpaceModelCMYK 类型,也不会进行透明度信息的填充。

另外,获取的图片,其宽和高都要小于 1024 且通道信息的位数不能大于 8 。之后,如果设备所支持的颜色空间模型为 kCGColorSpaceModelRGB 则可以对图片的透明度信息进行处理,分为下面两种情况:

  • 图片的 kCGBitmapAlphaInfoMask 值为 kCGImageAlphaNone 即图片没有透明度信息,那么透明度信息设置为 kCGImageAlphaNoneSkipFirst
  • 图片的 kCGBitmapAlphaInfoMask 值不是 kCGImageAlphaNoneSkipFirstkCGImageAlphaNoneSkipLast 时,设置为 kCGImageAlphaPremultipliedFirst

这两个属性不适用于 Mac OS X 系统中。

AFCompoundResponseSerializer

组合解析器,使用该类可以将多个解析器组合到一个解析器中,用于多种类型数据的解析,对于无法确定返回的数据类型的情况很方便,其实现的方式主要是在重写的协议方法中遍历 responseSerializers 属性中的所有解析器进行数据解析,一旦解析成功,则返回解析结果,否则继续使用下一个解析器。

这些解析器可以是自定义的,但是必需遵循 AFURLResponseSerialization 协议,当然,可能遍历结束后,数据仍然无法解析,参见下面的源码。

- (id)responseObjectForResponse:(NSURLResponse *)responsedata:(NSData *)dataerror:(NSError *__autoreleasing *)error
{for (id <AFURLResponseSerialization> serializer in self.responseSerializers) {if (![serializer isKindOfClass:[AFHTTPResponseSerializer class]]) {continue;}NSError *serializerError = nil;id responseObject = [serializer responseObjectForResponse:response data:data error:&serializerError];if (responseObject) {if (error) {*error = AFErrorWithUnderlyingError(serializerError, *error);}
return responseObject;}}
return [super responseObjectForResponse:response data:data error:error];
}

要注意的是,创建该类时,不能使用父类声明的 serializer 方法,而是要使用该类自己声明的类方法。

+ (instancetype)compoundSerializerWithResponseSerializers:(NSArray <id<AFURLResponseSerialization>> *)responseSerializers;

这篇关于AFNetworking 框架小结 二(AFURLResponseSerialization)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1036193

相关文章

MobaXterm远程登录工具功能与应用小结

《MobaXterm远程登录工具功能与应用小结》MobaXterm是一款功能强大的远程终端软件,主要支持SSH登录,拥有多种远程协议,实现跨平台访问,它包括多会话管理、本地命令行执行、图形化界面集成和... 目录1. 远程终端软件概述1.1 远程终端软件的定义与用途1.2 远程终端软件的关键特性2. 支持的

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

Spring AI Alibaba接入大模型时的依赖问题小结

《SpringAIAlibaba接入大模型时的依赖问题小结》文章介绍了如何在pom.xml文件中配置SpringAIAlibaba依赖,并提供了一个示例pom.xml文件,同时,建议将Maven仓... 目录(一)pom.XML文件:(二)application.yml配置文件(一)pom.xml文件:首

JS 实现复制到剪贴板的几种方式小结

《JS实现复制到剪贴板的几种方式小结》本文主要介绍了JS实现复制到剪贴板的几种方式小结,包括ClipboardAPI和document.execCommand这两种方法,具有一定的参考价值,感兴趣的... 目录一、Clipboard API相关属性方法二、document.execCommand优点:缺点:

Python创建Excel的4种方式小结

《Python创建Excel的4种方式小结》这篇文章主要为大家详细介绍了Python中创建Excel的4种常见方式,文中的示例代码简洁易懂,具有一定的参考价值,感兴趣的小伙伴可以学习一下... 目录库的安装代码1——pandas代码2——openpyxl代码3——xlsxwriterwww.cppcns.c

MyBatis-Flex BaseMapper的接口基本用法小结

《MyBatis-FlexBaseMapper的接口基本用法小结》本文主要介绍了MyBatis-FlexBaseMapper的接口基本用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具... 目录MyBATis-Flex简单介绍特性基础方法INSERT① insert② insertSelec

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依

Java通过反射获取方法参数名的方式小结

《Java通过反射获取方法参数名的方式小结》这篇文章主要为大家详细介绍了Java如何通过反射获取方法参数名的方式,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、解决方式方式2.1: 添加编译参数配置 -parameters方式2.2: 使用Spring的内部工具类 -

Python给Excel写入数据的四种方法小结

《Python给Excel写入数据的四种方法小结》本文主要介绍了Python给Excel写入数据的四种方法小结,包含openpyxl库、xlsxwriter库、pandas库和win32com库,具有... 目录1. 使用 openpyxl 库2. 使用 xlsxwriter 库3. 使用 pandas 库