AFN简介
目前国内开发网络应用使用最多的第三方框架
是专为 Mac OS & iOS 设计的一套网络框架
对 NSURLConnection 和 NSURLSession 做了封装
提供有丰富的 API
提供了完善的错误解决方案
使用简单
官网地址
https://github.com/AFNetworking/AFNetworking
使用
使用时导入头文件 : #import "AFNetworking.h".
数据格式
请求的数据格式
AFURLRequestSerialization
类型和说明
AFHTTPRequestSerializer 二进制的,默认的
AFJSONRequestSerializer JSON(POST JSON) RESTful 设计风格需要
AFPropertyListRequestSerializer PList(POST Plist-开发中几乎不用)
响应数据格式
AFURLResponseSerialization
类型和说明
AFHTTPResponseSerializer HTTP 二进制的
AFJSONResponseSerializer JSON 默认的
AFXMLParserResponseSerializer XML Parser 解析器 SAX 解析
AFXMLDocumentResponseSerializer (Mac OS X) XML DOM
AFPropertyListResponseSerializer PList 几乎不用
AFImageResponseSerializer 图像,不支持 GIF
AFCompoundResponseSerializer 组合的
数据格式小结
大多情况下,都是 JSON格式,不需要指定.
如果是 XML 格式
如果 SAX 解析,需要指定格式
manager.responseSerializer = [AFXMLParserResponseSerializer serializer];
然后利用代理方法解析
如果 DOM 解析,需要指定格式
manager.responseSerializer = [AFHTTPResponseSerializer serializer];
然后利用第三方框架解析
图像
AFN 支持图像缓存.
但是:不支持 GIF.
提示
使用 AFN 时,一定记住输出:error.
常见问题
AFN常见的序列化和反序列化的错误
1.常见错误一 :
AFN支持接收 @"application/json", @"text/json", @"text/javascript" 文本类型
AFN不支持接收 text/html 文本类型
2.常见错误二 :
AFN默认的成功的回调 responseObject 是把服务器返回的数据当做JSON数据格式解析,返回字典或者数组.
但是在加载网页数据时,响应体是字符串.需要修改响应的序列化方式,让AFN给我们返回原始的二进制数据即可.
3.常见错误三 :
AFN不支持接收 text/plian 文本类型
4.常见错误四 :
AFN默认只支持向服务器发送普通的二进制数据.比如普通的GET和POST请求数据.默认不支持发送JSON数据到服务器
如果要向服务器发送JSON格式的二进制数据,就需要特殊的处理请求的方式.使AFN支持向服务器发送JSON形式的二进制数据
常见错误一和常见错误二
加载网页数据时
- (void)loadData
{
// 网络请求manager
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
// 常见错误一 : 修改AFN支持接收的文本类型 : text/html
manager.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"application/json", @"text/json", @"text/javascript", @"text/html", nil];
// 常见错误二 : 修改AFN默认的返回的数据类型,设置默认为只返回原始的二进制数据,程序猿自己解析
manager.responseSerializer = [AFHTTPResponseSerializer serializer];
// 网络请求地址
NSString *URLStr = @"http://www.baidu.com";
// 发送网络请求
[manager GET:URLStr parameters:nil progress:nil success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
// NSLog(@"%@ %@",[responseObject class],responseObject);
NSString *html = [[NSString alloc] initWithData:responseObject encoding:NSUTF8StringEncoding];
NSLog(@"%@",html);
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
NSLog(@"出错 %@",error);
}];
}
常见错误三和常见错误四
向服务器发送JSON数据时
- (void)postJSON
{
// 网络请求manager
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
// 常见错误三 : 修改AFN支持接收的文本类型 : text/plian
manager.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"application/json", @"text/json", @"text/javascript", @"text/html", @"text/plain", nil];
// 常见错误二 : 修改AFN默认的返回的数据类型,设置默认为只返回原始的二进制数据,程序猿自己解析
manager.responseSerializer = [AFHTTPResponseSerializer serializer];
// 常见错误四 : 修改AFN支持向服务器发送JSON形式的二进制数据
manager.requestSerializer = [AFJSONRequestSerializer serializer];
// 网络请求地址
NSString *URLStr = @"http://localhost/php/upload/postjson.php";
// 请求参数
NSDictionary *parameters = @{
@"name":@"zhangsan"
};
// 发送网络请求
[manager POST:URLStr parameters:parameters progress:nil success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
// NSLog(@"%@ %@",[responseObject class],responseObject);
NSString *html = [[NSString alloc] initWithData:responseObject encoding:NSUTF8StringEncoding];
NSLog(@"%@",html);
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
NSLog(@"出错 %@",error);
}];
}