AFNetworking 使用

AFNetworking是一个轻量级的iOS网络通信类库。它建立在NSURLConnection和NSOperation等类库的基础上,让很多网络通信功能的实现变得十分简单。它支持HTTP请求和基于REST的网络服务(包括GET、POST、 PUT、DELETE等)。支持ARC。

Github地址:https://github.com/AFNetworking/AFNetworking

[objc] view plaincopy

    1. //
    2. //  MJViewController.m
    3. //  03.AFN演练
    4. //
    5. //  Created by apple on 14-4-30.
    6. //  Copyright (c) 2014年 itcast. All rights reserved.
    7. //
    8. #import "MJViewController.h"
    9. #import "AFNetworking.h"
    10. @interface MJViewController ()
    11. @end
    12. @implementation MJViewController
    13. /**
    14. 要使用常规的AFN网络访问
    15. 1. AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
    16. 所有的网络请求,均有manager发起
    17. 2. 需要注意的是,默认提交请求的数据是二进制的,返回格式是JSON
    18. 1> 如果提交数据是JSON的,需要将请求格式设置为AFJSONRequestSerializer
    19. 2> 如果返回格式不是JSON的,
    20. 3. 请求格式
    21. AFHTTPRequestSerializer            二进制格式
    22. AFJSONRequestSerializer            JSON
    23. AFPropertyListRequestSerializer    PList(是一种特殊的XML,解析起来相对容易)
    24. 4. 返回格式
    25. AFHTTPResponseSerializer           二进制格式
    26. AFJSONResponseSerializer           JSON
    27. AFXMLParserResponseSerializer      XML,只能返回XMLParser,还需要自己通过代理方法解析
    28. AFXMLDocumentResponseSerializer (Mac OS X)
    29. AFPropertyListResponseSerializer   PList
    30. AFImageResponseSerializer          Image
    31. AFCompoundResponseSerializer       组合
    32. */
    33. - (void)viewDidLoad
    34. {
    35. [super viewDidLoad];
    36. [self reach];
    37. }
    38. #pragma mark - 演练
    39. #pragma mark - 检测网络连接
    40. - (void)reach
    41. {
    42. /**
    43. AFNetworkReachabilityStatusUnknown          = -1,  // 未知
    44. AFNetworkReachabilityStatusNotReachable     = 0,   // 无连接
    45. AFNetworkReachabilityStatusReachableViaWWAN = 1,   // 3G 花钱
    46. AFNetworkReachabilityStatusReachableViaWiFi = 2,   // 局域网络,不花钱
    47. */
    48. // 如果要检测网络状态的变化,必须用检测管理器的单例的startMonitoring
    49. [[AFNetworkReachabilityManager sharedManager] startMonitoring];
    50. // 检测网络连接的单例,网络变化时的回调方法
    51. [[AFNetworkReachabilityManager sharedManager] setReachabilityStatusChangeBlock:^(AFNetworkReachabilityStatus status) {
    52. NSLog(@"%d", status);
    53. }];
    54. }
    55. #pragma mark - Session 下载
    56. - (void)sessionDownload
    57. {
    58. NSURLSessionConfiguration *config = [NSURLSessionConfiguration defaultSessionConfiguration];
    59. AFURLSessionManager *manager = [[AFURLSessionManager alloc] initWithSessionConfiguration:config];
    60. NSString *urlString = @"http://localhost/itcast/videos/01.C语言-语法预览.mp4";
    61. urlString = [urlString stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
    62. NSURL *url = [NSURL URLWithString:urlString];
    63. NSURLRequest *request = [NSURLRequest requestWithURL:url];
    64. NSURLSessionDownloadTask *task = [manager downloadTaskWithRequest:request progress:nil destination:^NSURL *(NSURL *targetPath, NSURLResponse *response) {
    65. // 指定下载文件保存的路径
    66. //        NSLog(@"%@ %@", targetPath, response.suggestedFilename);
    67. // 将下载文件保存在缓存路径中
    68. NSString *cacheDir = NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES)[0];
    69. NSString *path = [cacheDir stringByAppendingPathComponent:response.suggestedFilename];
    70. // URLWithString返回的是网络的URL,如果使用本地URL,需要注意
    71. NSURL *fileURL1 = [NSURL URLWithString:path];
    72. NSURL *fileURL = [NSURL fileURLWithPath:path];
    73. NSLog(@"== %@ |||| %@", fileURL1, fileURL);
    74. return fileURL;
    75. } completionHandler:^(NSURLResponse *response, NSURL *filePath, NSError *error) {
    76. NSLog(@"%@ %@", filePath, error);
    77. }];
    78. [task resume];
    79. }
    80. #pragma mark - POST JSON
    81. - (void)postJSON
    82. {
    83. AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
    84. NSDictionary *dict = @{@"name": @"zhangsan"};
    85. NSDictionary *dict1 = @{@"name": @"wangwu"};
    86. NSArray *array = @[dict, dict1];
    87. // 设置请求格式
    88. manager.requestSerializer = [AFJSONRequestSerializer serializer];
    89. // 设置返回格式
    90. manager.responseSerializer = [AFHTTPResponseSerializer serializer];
    91. [manager POST:@"http://localhost/postjson.php" parameters:array success:^(AFHTTPRequestOperation *operation, id responseObject) {
    92. NSString *result = [[NSString alloc] initWithData:responseObject encoding:NSUTF8StringEncoding];
    93. NSLog(@"%@", result);
    94. } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
    95. }];
    96. }
    97. #pragma mark - 随机文件名上传
    98. - (void)postUpload1
    99. {
    100. // 本地上传给服务器时,没有确定的URL,不好用MD5的方式处理
    101. AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
    102. manager.responseSerializer = [AFHTTPResponseSerializer serializer];
    103. [manager POST:@"http://localhost/demo/upload.php" parameters:nil constructingBodyWithBlock:^(id<AFMultipartFormData> formData) {
    104. NSURL *fileURL = [[NSBundle mainBundle] URLForResource:@"头像1.png" withExtension:nil];
    105. // 要上传保存在服务器中的名称
    106. // 使用时间来作为文件名 2014-04-30 14:20:57.png
    107. // 让不同的用户信息,保存在不同目录中
    108. NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
    109. // 设置日期格式
    110. formatter.dateFormat = @"yyyy-MM-dd HH:mm:ss";
    111. NSString *fileName = [formatter stringFromDate:[NSDate date]];
    112. [formData appendPartWithFileURL:fileURL name:@"uploadFile" fileName:fileName mimeType:@"image/png" error:NULL];
    113. } success:^(AFHTTPRequestOperation *operation, id responseObject) {
    114. NSLog(@"OK");
    115. } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
    116. NSLog(@"error");
    117. }];
    118. }
    119. #pragma mark - POST上传
    120. - (void)postUpload
    121. {
    122. AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
    123. // AFHTTPResponseSerializer就是正常的HTTP请求响应结果:NSData
    124. // 当请求的返回数据不是JSON,XML,PList,UIImage之外,使用AFHTTPResponseSerializer
    125. // 例如返回一个html,text...
    126. //
    127. // 实际上就是AFN没有对响应数据做任何处理的情况
    128. manager.responseSerializer = [AFHTTPResponseSerializer serializer];
    129. // formData是遵守了AFMultipartFormData的对象
    130. [manager POST:@"http://localhost/demo/upload.php" parameters:nil constructingBodyWithBlock:^(id<AFMultipartFormData> formData) {
    131. // 将本地的文件上传至服务器
    132. NSURL *fileURL = [[NSBundle mainBundle] URLForResource:@"头像1.png" withExtension:nil];
    133. [formData appendPartWithFileURL:fileURL name:@"uploadFile" error:NULL];
    134. } success:^(AFHTTPRequestOperation *operation, id responseObject) {
    135. NSString *result = [[NSString alloc] initWithData:responseObject encoding:NSUTF8StringEncoding];
    136. NSLog(@"完成 %@", result);
    137. } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
    138. NSLog(@"错误 %@", error.localizedDescription);
    139. }];
    140. }
    141. #pragma mark - JSON
    142. - (void)XMLData
    143. {
    144. AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
    145. // 返回的数据格式是XML
    146. manager.responseSerializer = [AFXMLParserResponseSerializer serializer];
    147. NSDictionary *dict = @{@"format": @"xml"};
    148. // 网络访问是异步的,回调是主线程的,因此程序员不用管在主线程更新UI的事情
    149. [manager GET:@"http://localhost/videos.php" parameters:dict success:^(AFHTTPRequestOperation *operation, id responseObject) {
    150. // 如果结果是XML,同样需要使用6个代理方法解析,或者使用第三方库
    151. // 第三方库第三方框架,效率低,内存泄漏
    152. NSLog(@"%@", responseObject);
    153. } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
    154. NSLog(@"%@", error);
    155. }];
    156. }
    157. #pragma mark - JSON
    158. - (void)JSONData
    159. {
    160. AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
    161. // 原本需要拼接get访问URL ? & =
    162. NSDictionary *dict = @{@"format": @"json"};
    163. // 网络访问是异步的,回调是主线程的,因此程序员不用管在主线程更新UI的事情
    164. [manager GET:@"http://localhost/videos.php" parameters:dict success:^(AFHTTPRequestOperation *operation, id responseObject) {
    165. NSLog(@"%@", responseObject);
    166. // 提问:NSURLConnection异步方法回调,是在子线程
    167. // 得到回调之后,通常更新UI,是在主线程
    168. NSLog(@"%@", [NSThread currentThread]);
    169. } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
    170. NSLog(@"%@", error);
    171. }];
    172. }
    173. #pragma mark - POST登录
    174. - (void)postLogin
    175. {
    176. AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
    177. // 原本需要拼接get访问URL ? & =
    178. NSDictionary *dict = @{@"username": @"wangwu", @"password" : @"wang"};
    179. // 网络访问是异步的,回调是主线程的,因此程序员不用管在主线程更新UI的事情
    180. [manager POST:@"http://localhost/login.php" parameters:dict success:^(AFHTTPRequestOperation *operation, id responseObject) {
    181. NSLog(@"%@", responseObject);
    182. // 提问:NSURLConnection异步方法回调,是在子线程
    183. // 得到回调之后,通常更新UI,是在主线程
    184. NSLog(@"%@", [NSThread currentThread]);
    185. } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
    186. NSLog(@"%@", error);
    187. }];
    188. }
    189. #pragma mark - GET登录
    190. - (void)getLogin
    191. {
    192. AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
    193. // 原本需要拼接get访问URL ? & =
    194. NSDictionary *dict = @{@"username": @"wangwu", @"password" : @"wang"};
    195. // 网络访问是异步的,回调是主线程的,因此程序员不用管在主线程更新UI的事情
    196. [manager GET:@"http://localhost/login.php" parameters:dict success:^(AFHTTPRequestOperation *operation, id responseObject) {
    197. NSLog(@"%@", responseObject);
    198. // 提问:NSURLConnection异步方法回调,是在子线程
    199. // 得到回调之后,通常更新UI,是在主线程
    200. NSLog(@"%@", [NSThread currentThread]);
    201. } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
    202. NSLog(@"%@", error);
    203. }];
    204. }
    205. @end
时间: 2024-08-09 19:52:29

AFNetworking 使用的相关文章

ios AFNetworking 3.0 原码阅读分析 (一)(AFURLRequestSerialization)

本文主要内容是讲AFNetworking中的AFURLRequestSerialization.它主要的作用是在我们要发送一个网络请求的时候帮助我们创NSMutableURLRequest并封装好所需要的参数到NSMutableURLRequest中.那它内部做了些什么,提供了什么功能,使得我们进行网络请求时候变得如此方便.简单.好像我们什么都不用管就能建立一个正确的请求体NSURLRequest.接下来就会一步步揭开它神秘的面纱. 概览 首先看一下在AFURLRequestSerializat

AFNetworking 3.0x版本最新特性

AFNetworking是一款在OS X和iOS下都令人喜爱的网络库.为了迎合iOS新版本的升级, AFNetworking在3.0版本中删除了基于 NSURLConnection API的所有支持.如果你的项目以前使用过这些API,建议您立即升级到基于 NSURLSession 的API的AFNetworking的版本.本指南将引导您完成这个过程. 本指南是为了引导使用AFNetworking 2.x升级到最新的版本API,以达到过渡的目的,并且解释了新增和更改的设计结构. 新设备要求: iO

AFNetworking发送和接收字符串时报3840错误的解决办法

AFNetworking框架默认请求类型和响应类型都是JSON格式的,在特殊情况下,我们使用字符串形式的时候,就会报3840错误,如何解决呢? 设置请求管理者: // 因为传递过去和接收回来的数据都不是json类型的,所以在这里要设置为AFHTTPRequestSerializer和AFHTTPResponseSerializer mgr.requestSerializer = [AFHTTPRequestSerializer serializer];// 请求 mgr.responseSeri

iOS开发 之 AFNetworking的基本使用

首先下载AFNetworking 然后在需要使用的类中,导入如下2个头文件: #import "AFNetworking.h"//主要用于网络请求方法 #import "UIKit+AFNetworking.h"//里面有异步加载图片的方法 GET请求网络数据方式: -(void)obtainData {     // 启动系统风火轮     [UIApplication sharedApplication].networkActivityIndicatorVisi

AFNetworking imageView button设置图片缓存

如果对AFNetworking 下载的图片不进行缓存,可能会导致每次加载  image图片的时候都会重新 下载图片; 严重浪费资源: AFNetworking有自带的很方便的配置缓存图片的方法: 在 UIKit+AFNetworking中, imageView和Button的类目都可以设置缓存: 方法如下: button [UIButton setSharedImageCache:[UIButton sharedImageCache]]; imageView [UIImageView setSh

AFNetworking 2.5.0版本的使用

http://afnetworking.com/ http://cocoadocs.org/docsets/AFNetworking/2.5.0/ 1. 下载源码并进行编译 源码地址 http://pan.baidu.com/s/1jG24w3W 2. 判断当前是否有网络,基准网址为 http://baidu.com/ 源码: 可以用来监测WWAN或者WiFi或者断网状态;) // 基准baseURL NSURL *baseURL = [NSURL URLWithString:@"http://

AFNetworking的使用

AFN  1 AFN的框架结构 NSURLSession: NSURLSessionManager(对NSURLSession的封装); AFHttpSessionManager(会话管理者) 序列化处理serialization: AFURLRequestSerialization(请求); AFURLResponseSerialization(响应) 扩展功能: AFSecurityPolicy(安全); AFNetworkReachabilityManager(监听) UIKit+AFNe

iOS 网络编程:AFNetworking

1 简介 1.1 概念 AFNetworking网络框架并不是IOS自带的框架,而是第三方的开源框架.它是对NSURLConnection和NSURLSession API的封装,但是目前AFNetworking 3.0已经删除了基于 NSURLConnection API的所有支持,所以本文只记录基于NSURLSession API的相关接口.AFNetworking 框架是基于Object-C语言,若需要使用Swift语言版可以了解Alamofire框架. 个人感觉学习AFNetworkin

ios开发中-AFNetworking 的简单介绍

Blog: Draveness 关注仓库,及时获得更新: iOS-Source-Code-Analyze 在这一系列的文章中,我会对 AFNetworking 的源代码进行分析,深入了解一下它是如何构建的,如何在日常中完成发送 HTTP 请求.构建网络层这一任务. AFNetworking 是如今 iOS 开发中不可缺少的组件之一.它的 github 配置上是如下介绍的: Perhaps the most important feature of all, however, is the ama

AFNetworking 3.0迁移指南

AFNetworking是一款在OS X和iOS下都令人喜爱的网络库.为了迎合iOS新版本的升级, AFNetworking在3.0版本中删除了基于 NSURLConnection API的所有支持.如果你的项目以前使用过这些API,建议您立即升级到基于 NSURLSession 的API的AFNetworking的版本.本指南将引导您完成这个过程. 本指南是为了引导使用AFNetworking 2.x升级到最新的版本API,以达到过渡的目的,并且解释了新增和更改的设计结构. 新设备要求: iO