iOS AFNetworking 3.0以上使用

Posted 蓝天下的田埂上

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了iOS AFNetworking 3.0以上使用相关的知识,希望对你有一定的参考价值。

在Xcode7.0之后,苹果废弃了NSURLConnection方法,数据请求使用NSURLSession,作为网络请求类第三方库使用量最大的AFN也及时的更新的新的版本——AFN 3.0版本。新的版本的里废弃了基于NSURLConnection封装的AFHTTPRequestOperationManager,转而使用基于NSURLSession封装的AFHTTPSessionManager了。

下面将详细介绍AFN3.0的使用

1.cocoapods导入AFN 3.0

1.1 进入到工程目录下

$ cd 工程目录名

1.2 搜索最新的AFN库版本

$ pod search AFNetworking

1.3 创建podfile文件

$ vim podfile

1.4 按下键盘“i”键,输入如下的pod语句,然后按下“esc”键,退出编辑,再输入“:wq”,保存退出vim,项目根目录下就会新建我们需要的podfile文件

$ platform:iOS,‘7.0‘
$ pod ‘AFNetworking‘,‘~>3.1.0‘

1.5 导入AFN库,使用如下语句导入和直接$ pod install的区别是略过cocoaPods的库更新过程,导入速度较快

$ pod install --verbose --no-repo-update

导入成功,使用后缀名为.xcworkspace的文件打开工程

 

2.配置plist文件

 

在Xcode 7.0之后,苹果使用了https的网路协议,所以在网络请求前,我们还需要配置一下工程的Info.plist文件

右键Info.plist文件  ->  open as ->  source code ,找到下图位置,粘贴如下代码

[objc] view plain copy
 技术分享技术分享
  1. <key>NSAppTransportSecurity</key>  
  2.     <dict>  
  3.         <key>NSAllowsArbitraryLoads</key>  
  4.         <true/>  
  5.     </dict>  

技术分享

3.使用AFN进行数据请求

3.1 请求管理类 (HttpsManager)

该类里都是+号方法,不是单例类

在.h里定义超时时间宏,以及成功和失败的block块

 
  1. #define kTimeOutInterval 30 // 请求超时的时间  
  2. typedef void (^SuccessBlock)(NSDictionary *dict, BOOL success); // 访问成功block  
  3. typedef void (^AFNErrorBlock)(NSError *error); // 访问失败block  


封装AFN请求管理者

 
  1. #pragma mark - 创建请求者  
  2. +(AFHTTPSessionManager *)manager  
  3. {  
  4.     AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];  
  5.     // 超时时间  
  6.     manager.requestSerializer.timeoutInterval = kTimeOutInterval;  
  7.       
  8.     // 声明上传的是json格式的参数,需要你和后台约定好,不然会出现后台无法获取到你上传的参数问题  
  9.     manager.requestSerializer = [AFHTTPRequestSerializer serializer]; // 上传普通格式  
  10. //    manager.requestSerializer = [AFJSONRequestSerializer serializer]; // 上传JSON格式  
  11.       
  12.     // 声明获取到的数据格式  
  13.     manager.responseSerializer = [AFHTTPResponseSerializer serializer]; // AFN不会解析,数据是data,需要自己解析  
  14. //    manager.responseSerializer = [AFJSONResponseSerializer serializer]; // AFN会JSON解析返回的数据  
  15.     // 个人建议还是自己解析的比较好,有时接口返回的数据不合格会报3840错误,大致是AFN无法解析返回来的数据  
  16.     return manager;  
  17. }  

3.2 get

  1. + (void)getUserCarShopAndSalesDataForSalesWithUserId:(NSString *)userId date:(NSString *)date selectAreaType:(NSString *)areaType Success:(SuccessBlock)success fail:(AFNErrorBlock)fail  
  2. {  
  3.     // get请求也可以直接将参数放在字典里,AFN会自己讲参数拼接在url的后面,不需要自己凭借  
  4.     NSDictionary *param = @{@"user_id":userId, @"sale_date":date, @"accessToken":@"e9c0e60318ebd07ec2fe", @"area_type":areaType};  
  5.     // 创建请求类  
  6.     AFHTTPSessionManager *manager = [self manager];  
  7.     [manager GET:@"http://pm.yunhan-china.com/index.php/Api_sale/sales_get" parameters:param progress:^(NSProgress * _Nonnull downloadProgress) {  
  8.         // 这里可以获取到目前数据请求的进度  
  9.     } success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {  
  10.         // 请求成功  
  11.         if(responseObject){  
  12.             NSDictionary *dict = [NSJSONSerialization JSONObjectWithData:responseObject options:NSJSONReadingMutableContainers error:nil];  
  13.             success(dict,YES);  
  14.         } else {  
  15.             success(@{@"msg":@"暂无数据"}, NO);  
  16.         }  
  17.     } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {  
  18.         // 请求失败  
  19.         fail(error);  
  20.     }];  
  21. }   

3.3 post

  1. + (void)loginWithUserAccount:(NSString *)account password:(NSString *)password success:(SuccessBlock)success fail:(AFNErrorBlock)fail  
  2. {  
  3.     // 将请求参数放在请求的字典里  
  4.     NSDictionary *param = @{@"phoneNumber":account, @"password":@"f379eaf3c831b04de153469d1bec345e"};  
  5.     // 创建请求类  
  6.     AFHTTPSessionManager *manager = [self manager];  
  7.     [manager POST:@"http://pm.yunhan-china.com/index.php/api_common/login" parameters:param progress:^(NSProgress * _Nonnull uploadProgress) {  
  8.         // 这里可以获取到目前数据请求的进度  
  9.     } success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {  
  10.         // 请求成功  
  11.         if(responseObject){  
  12.             NSDictionary *dict = [NSJSONSerialization JSONObjectWithData:responseObject options:NSJSONReadingMutableContainers error:nil];  
  13.             success(dict,YES);  
  14.         } else {  
  15.             success(@{@"msg":@"暂无数据"}, NO);  
  16.         }  
  17.     } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {  
  18.         // 请求失败  
  19.         fail(error);  
  20.     }];  
  21.       
  22. }  

3.4 下载

 
  1. - (void)downLoadWithUrlString:(NSString *)urlString  
  2. {  
  3.     // 1.创建管理者对象  
  4.     AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];  
  5.     // 2.设置请求的URL地址  
  6.     NSURL *url = [NSURL URLWithString:urlString];  
  7.     // 3.创建请求对象  
  8.     NSURLRequest *request = [NSURLRequest requestWithURL:url];  
  9.     // 4.下载任务  
  10.     NSURLSessionDownloadTask *task = [manager downloadTaskWithRequest:request progress:^(NSProgress * _Nonnull downloadProgress) {  
  11.         // 下载进度  
  12.         NSLog(@"当前下载进度为:%lf", 1.0 * downloadProgress.completedUnitCount / downloadProgress.totalUnitCount);  
  13.     } destination:^NSURL * _Nonnull(NSURL * _Nonnull targetPath, NSURLResponse * _Nonnull response) {  
  14.         // 下载地址  
  15.         NSLog(@"默认下载地址%@",targetPath);  
  16.         // 设置下载路径,通过沙盒获取缓存地址,最后返回NSURL对象  
  17.         NSString *filePath = [NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES)lastObject];  
  18.         return [NSURL fileURLWithPath:filePath]; // 返回的是文件存放在本地沙盒的地址  
  19.     } completionHandler:^(NSURLResponse * _Nonnull response, NSURL * _Nullable filePath, NSError * _Nullable error) {  
  20.         // 下载完成调用的方法  
  21.         NSLog(@"%@---%@", response, filePath);  
  22.     }];  
  23.     // 5.启动下载任务  
  24.     [task resume];  
  25. }  

3.5 上传

 
  1. - (void)uploadWithUser:(NSString *)userId UrlString:(NSString *)urlString upImg:(UIImage *)upImg  
  2. {  
  3.     // 创建管理者对象  
  4.     AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];  
  5.     // 参数  
  6.     NSDictionary *param = @{@"user_id":userId};  
  7.     [manager POST:urlString parameters:param constructingBodyWithBlock:^(id<AFMultipartFormData>  _Nonnull formData) {  
  8.         /******** 1.上传已经获取到的img *******/  
  9.         // 把图片转换成data  
  10.         NSData *data = UIImagePNGRepresentation(upImg);  
  11.         // 拼接数据到请求题中  
  12.         [formData appendPartWithFileData:data name:@"file" fileName:@"123.png" mimeType:@"image/png"];  
  13.         /******** 2.通过路径上传沙盒或系统相册里的图片 *****/  
  14. //        [formData appendPartWithFileURL:[NSURL fileURLWithPath:@"文件地址"] name:@"file" fileName:@"1234.png" mimeType:@"application/octet-stream" error:nil];  
  15.           
  16.     } progress:^(NSProgress * _Nonnull uploadProgress) {  
  17.         // 打印上传进度  
  18.         NSLog(@"%lf",1.0 *uploadProgress.completedUnitCount / uploadProgress.totalUnitCount);  
  19.     } success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {  
  20.         //请求成功  
  21.         NSLog(@"请求成功:%@",responseObject);  
  22.           
  23.     } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {  
  24.         //请求失败  
  25.         NSLog(@"请求失败:%@",error);  
  26.     }];  
  27. }  
  28. 3.6 网络监听
 
    1. - (void)AFNetworkStatus{  
    2.       
    3.     //1.创建网络监测者  
    4.     AFNetworkReachabilityManager *manager = [AFNetworkReachabilityManager sharedManager];  
    5.       
    6.     /*枚举里面四个状态  分别对应 未知 无网络 数据 WiFi 
    7.      typedef NS_ENUM(NSInteger, AFNetworkReachabilityStatus) { 
    8.      AFNetworkReachabilityStatusUnknown          = -1,      未知 
    9.      AFNetworkReachabilityStatusNotReachable     = 0,       无网络 
    10.      AFNetworkReachabilityStatusReachableViaWWAN = 1,       蜂窝数据网络 
    11.      AFNetworkReachabilityStatusReachableViaWiFi = 2,       WiFi 
    12.      }; 
    13.      */  
    14.       
    15.     [manager setReachabilityStatusChangeBlock:^(AFNetworkReachabilityStatus status) {  
    16.         //这里是监测到网络改变的block  可以写成switch方便  
    17.         //在里面可以随便写事件  
    18.         switch (status) {  
    19.             case AFNetworkReachabilityStatusUnknown:  
    20.                 NSLog(@"未知网络状态");  
    21.                 break;  
    22.             case AFNetworkReachabilityStatusNotReachable:  
    23.                 NSLog(@"无网络");  
    24.                 break;  
    25.                   
    26.             case AFNetworkReachabilityStatusReachableViaWWAN:  
    27.                 NSLog(@"蜂窝数据网");  
    28.                 break;  
    29.                   
    30.             case AFNetworkReachabilityStatusReachableViaWiFi:  
    31.                 NSLog(@"WiFi网络");  
    32.                   
    33.                 break;  
    34.                   
    35.             default:  
    36.                 break;  
    37.         }  
    38.           
    39.     }] ;  


以上是关于iOS AFNetworking 3.0以上使用的主要内容,如果未能解决你的问题,请参考以下文章

AFNetworking 3.0迁移指南

AFNetworking 3.0x版本最新特性

iOS 9 平台上 AFNetworking 框架 3.0 版本号解决的问题和问题解决

iOS-AFNetworking3.0上传大量(1000张)图片到服务器

Cocoapods 集成AFNetworking从2.0版本升级到3.0版本的问题

AFNetworking 3.0 GET 请求在 iOS 中保存到类中