iOS--AFN实现原理

 

iOS--AFN实现原理

标签: AFN网络iOS
  312人阅读  评论(0)  收藏  举报
  分类:

目录(?)[+]

AFN的六大模块


1,NSURLConnection

主要对NSURLConnection进行了进一步的封装,包含以下核心的类:

AFURLConnectionOperation

AFHTTPRequestOperationManager

AFHTTPRequestOperation


2,NSURLsession

主要对象NSURLSession对象进行了进一步的封装,包含以下核心的类:

AFURLSessionManager

AFHTTPSessionManager


3,Reachability

提供了与网络状态相关的操作接口,包含以下核心的类:

AFNetworkReachabilityManager


4,Security

提供了与安全性相关的操作接口,包含以下核心的类:

AFSecurityPolicy


5,Serialization

提供了与解析数据相关的操作接口,包含以下核心的类:

AFURLRequestSerialization

AFURLResponseSerialization


6,UIKit

提供了大量网络请求过程中与UI界面显示相关的操作接口,通常用于网络请求过程中提示,使用户交互更加友好,包含以下核心的分类/类:

AFNetworkActivityIndicatorManager

UIActivityIndicatorView+AFNetworking

UIAlertView+AFNetworking

UIButton+AFNetworking

UIImageView+AFNetworking

UIKit+AFNetworking

UiprogressView+AFNetworking

UIRefreshControl+AFNetworking

UIWebView+AFNetworking


AFURLSessionManager


创建任务的方法


普通任务
    • - (NSURLSessionDataTask *)dataTaskWithRequest:(NSURLRequest *)request completionHandler:(void (^)(NSURLResponse *response, id responSEObject, NSError *error))completionHandler

      /**

       * request:请求对象

       * completionHandler:请求完成调用的Block

      * response:服务器的响应信息

      * responseObject:服务器返回的数据

      * error:错误信息

       */

      上传任务(分别上传不同类型的文件)

      // 1. 上传文件类型的数据

      /**

       * fileURL:所要上传文件的路径

       */


      - (NSURLSessionUploadTask *)uploadTaskWithRequest:(NSURLRequest *)request fromFile:(NSURL *)fileURL progress:(NSProgress * __autoreleasing *)progress completionHandler:(void (^)(NSURLResponse *response, id responseObject, NSError *error))completionHandler


      // 2. 上传NSData类型的数据

      - (NSURLSessionUploadTask *)uploadTaskWithRequest:(NSURLRequest *)request fromData:(NSData *)bodyData progress:(NSProgress * __autoreleasing *)progress completionHandler:(void (^)(NSURLResponse *response, id responseObject, NSError *error))completionHandler

      /**

       * bodyData:所要上传的文件数据

       */

      // 3. 上传流数据

      - (NSURLSessionUploadTask *)uploadTaskWithStreamedRequest:(NSURLRequest *)request progress:(NSProgress * __autoreleasing *)progress completionHandler:(void (^)(NSURLResponse *response, id responseObject, NSError *error))completionHandler

      /**

       * request:通过流数据初始化的请求对象

       */

      下载任务

      // 1. 普通下载任务

      - (NSURLSessionDownloadTask *)downloadTaskWithRequest:(NSURLRequest *)request progress:(NSProgress * __autoreleasing *)progress destination:(NSURL * (^)(NSURL *targetPath, NSURLResponse *response))destination completionHandler:(void (^)(NSURLResponse *response, NSURL *filePath, NSError *error))completionHandler

      /**

       * progress:管理下载进度

       * destination:保存数据调用的Block

      * targetPath:数据的保存路径

       */

      // 2. 支持断点下载的下载任务

      - (NSURLSessionDownloadTask *)downloadTaskWithResumeData:(NSData *)resumeData progress:(NSProgress * __autoreleasing *)progress destination:(NSURL * (^)(NSURL *targetPath, NSURLResponse *response))destination completionHandler:(void (^)(NSURLResponse *response, NSURL *filePath, NSError *error))completionHandler

      /**

       * progress:管理下载进度

       * resumeData:断点下载时的断点信息

       */

      AFHTTPSessionManager

      常用的属性

      baseURL(NSURL *),用于监视网络可达性与创建请求对象

      requestSerializer(AFHTTPRequestSerializer *),指定指定GETHEADDELETE请求参数的解析格式

      responseSerializer(AFHTTPResponseSerializer *),用于指定服务器返回数据的格式

      常用方法

      初始化

      // 1. 通过工厂方法创建AFHTTPSessionManager对象

      + (instancetype)manager

      // 2. 通过构造方法创建AFHTTPSessionManager对象

      - (instancetype)initWithBaseURL:(NSURL *)url

      /**

       * 根据url初始化AFHTTPSessionManager对象

       */

      - (instancetype)initWithBaseURL:(NSURL *)url sessionConfiguration:(NSURLSessionConfiguration *)configuration

      /**

       * 根据urlconfiguration初始化AFHTTPSessionManager对象

       */

      请求数据

      // 1. GET请求

      - (NSURLSessionDataTask *)GET:(NSString *)URLString parameters:(id)parameters success:(void (^)(NSURLSessionDataTask *task, id responseObject))success failure:(void (^)(NSURLSessionDataTask *task, NSError *error))failure

      /**

       * URLString:请求路径

       * parameters:请求参数

       * success:请求成功时调用的Block

      * responseObject:服务器返回的数据

       * failure:请求失败时调用的Block

      * error:错误信息

       */

      // 2. POST请求

      - (NSURLSessionDataTask *)POST:(NSString *)URLString parameters:(id)parameters success:(void (^)(NSURLSessionDataTask *task, id responseObject))success failure:(void (^)(NSURLSessionDataTask *task, NSError *error))failure

      /**

       * 参数含义与GET请求相同

       */

      - (NSURLSessionDataTask *)POST:(NSString *)URLString parameters:(id)parameters constructingBodyWithBlock:(void (^)(id <AFMultipartFormData> formData))block success:(void (^)(NSURLSessionDataTask *task, id responseObject))success failure:(void (^)(NSURLSessionDataTask *task, NSError *error))failure

      /**

       * block:用于创建多个数据来源

       */

      使用AFN请求网络数据

      请求数据(xml/JSON

      创建AFHTTPSessionManager对象

      AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];

      指定对服务器的返回数据格式

      //XML文档的形式返回数据

      manager.responseSerializer = [AFXMLParserResponseSerializer serializer];

      //JSON形式返回数据

      manager.responseSerializer = [AFJSONResponseSerializer serializer];

      设置请求体(类型为XMLJSON)

      // 请求体通常由服务器指定格式

      NSDictionary *params = @{

                               @"username" : @"账号",

                               @"pwd" : @"密码",

                               @"type" : @"XML/JSON"

                               };

      发送请求

      [manager GET:@"请求路径" parameters:params success:^(NSURLSessionDataTask *task, id responseObject) {

          //responseObject:服务器返回的数据

          NSLog(@"请求成功");

      } failure:^(NSURLSessionDataTask *task, NSError *error) {

          //error:错误信息

          NSLog(@"请求失败");

      }];

      上传数据

      创建AFHTTPSessionManager对象

      AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];

      创建上传任务

      /**基于NSURLConnection*/

      [manager POST:@"请求路径" parameters:@{@"用户名" : @"密码" constructingBodyWithBlock:^(id<AFMultipartFormData> formData) {

          //设置需要上传的文件

          NSData *data = [NSData dataWithContentsOfFile:@"所要长传文件的路径"];

          [formData appendPartWithFileData:data name:@"file" fileName:@"test.png" mimeType:@"image/png"];

      } success:^(NSURLSessionDataTask *task, id responseObject) {

          //上传成功

      } failure:^(NSURLSessionDataTask *task, NSError *error) {

          //上传失败

      }];

                                         

      /**基于NSURLSession*/

      [manager uploadTaskWithRequest:request fromData:data progress:progress completionHandler:^(NSURLResponse *response, id responseObject, NSError *error) {

          //上传数据成功

      }];

      下载数据

                                         

      创建AFHTTPSessionManager对象

                                         

          AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];

      创建下载任务

                                         

      /**基于NSURLSession*/

          [manager downloadTaskWithRequest:request progress:progress destination:^NSURL *(NSURL *targetPath, NSURLResponse *response) {

          // 存储下载数据是调用的Block

      } completionHandler:^(NSURLResponse *response, NSURL *filePath, NSError *error) {

          //下载完成时调用的Block

      }];

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
AFNetworking是一个基于Objective-C语言的iOS网络请求框架,它提供了一系列方便的API,帮助开发者快速地进行网络请求并处理响应内容。其原理是基于NSURLConnection和NSURLSession建立的网络请求,通过对网络请求的封装,提供了比原生API更加便捷的操作方式。 常用操作包括: 1. 发起网络请求:使用AFHTTPRequestOperationManager或AFHTTPSessionManager类的GET、POST等方法,可以方便地发起网络请求。 2. 设置请求参数:使用AFHTTPRequestOperationManager或AFHTTPSessionManager类的setParameterEncoding方法或AFHTTPRequestSerializer类的setQueryStringSerializationWithStyle方法,可以设置请求参数的编码格式。 3. 设置请求头:使用AFHTTPRequestOperationManager或AFHTTPSessionManager类的setValue:forHTTPHeaderField方法,可以设置请求头信息。 4. 处理响应数据:使用AFHTTPRequestOperation类的completionBlock或AFHTTPSessionManager类的dataTaskWithRequest:completionHandler方法,可以处理请求响应数据。 5. 下载文件:使用AFHTTPRequestOperation类的setDownloadProgressBlock和setCompletionBlockWithSuccess方法或AFHTTPSessionManager类的downloadTaskWithRequest:progress:destination:completionHandler方法,可以实现文件下载功能。 6. 上传文件:使用AFHTTPRequestOperationManager或AFHTTPSessionManager类的POST方法和AFHTTPRequestSerializer类的multipartFormRequestWithMethod:URLString:parameters:constructingBodyWithBlock方法,可以实现文件上传功能。 总体来说,AFNetworking提供了丰富的API和良好的封装,使得iOS开发者能够更加方便地进行网络请求和处理响应数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值