iOS開發之AFN的基本使用

本篇將從四個方面對iOS開發中常用到的AFNetworking框架進行講解:javascript

1、什麼是 AFN

2、爲何要使用 AFN

3、AFN 怎麼用

3、AFN和ASI的區別


 

1、什麼是 AFN

AFN 全稱爲 AFNetworking,是一個構建與在 NSURLConnection、NSOperation 以及其餘熟悉的 Founation 技術之上的一個第三方網絡框架。php

 


2、爲何要使用 AFN

AFN 對網絡請求部分作了很好的封裝,而且擁有良好的架構,豐富的api,以及模塊化構建方式,使得使用起來很是輕鬆.。java

 


3、AFN 怎麼用和他的幾種使用方法

AFN 主要使用在2個場景中:json

1、發送網絡請求api

2、實時監測網絡狀態安全

 

AFHTTPRequestOperationManager:內部封裝的是 NSUrlConnection,網絡請求管理類,用來負責發送網絡請求,是使用最多的一個類.服務器

AFHTTPSessionManager :內部封裝的是 NSUrlSession,網絡請求管理類,用來負責發送網絡請求,是使用作多的一個類.網絡

 

兩個網絡請求管理類定義的 API 徹底相同:架構

[[AFHTTPRequestOperationManager manager] GET:nil parameters:nil success:^(AFHTTPRequestOperation *operation, id responseObject) {
    //
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
    //
}];

[[AFHTTPSessionManager manager] GET:nil parameters:nil success:^(NSURLSessionDataTask *task, id responseObject) {
    //
} failure:^(NSURLSessionDataTask *task, NSError *error) {
    //
}];

 

一些主要的工具類:app

AFNetworkReachabilityManager.h :實時監測網絡狀態改變的管理類.

AFSecurityPolicy.h :HTTPS 須要使用.

AFURLRequestSerialization: 數據解析的時候會使用.

AFHTTPRequestSerializer:   萬能解析器/對服務器返回的數據不作任務處理.

AFJSONResponseSerializer:  JSON解析器.

AFXMLParserResponseSerializer:  XML解析器.

AFHTTPRequestOperationManager 對NSURLConnection的封裝.

 AFHTTPSessionManager 對NSURLSession的封裝.

 

1、AFHTTPSessionManager的基本使用步驟:

1.建立管理者

AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];

2.設置管理者的數據解析類型,默認爲 json 格式的解析,可手動修改成其餘類型,如 XML:

manager.responseSerializer = [AFXMLParserResponseSerializer serializer];

 

3.發送網絡請求 

NSDictionary *dict = @{@"username":@"zhangsan",@"password":@"zhang"};

[[AFHTTPSessionManager manager] POST:@"http://localhost/login/login.php" parameters:dict progress:^(NSProgress * _Nonnull uploadProgress) {
    //
} success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {
    //
    NSLog(@"responseObject:%@",responseObject);
    
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
    //
    NSLog(@"error:%@",error);
}];

[[AFHTTPSessionManager manager] GET:@"http://localhost/login/login.php" parameters:dict progress:^(NSProgress * _Nonnull downloadProgress) {
    
    NSLog(@"下載進度:%@",downloadProgress);
    
} success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {
    
    NSLog(@"responseObject:%@",responseObject);
    
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
    
    NSLog(@"error:%@",error);
}];

 

 3.1 首先要明確發送的是什麼類型的請求(GET/POST/HEAD...)

 

 3.2 AFN 3.0以後的網絡接口相比以前的網絡接口多了一個參數:網絡進度.

 參數:

     1. urlString: 網絡接口地址.

     2. parameters: 參數字典.key:服務器接收普通參數的key值,value就是參數內容.

     3. progress: 網絡進度

     4. success: 成功回調

     5. failure: 失敗回調

 

 3.3 AFN根據 response.MIMEType 來判斷服務器返回數據的類型. 若是類型不匹配,可是又是JSON數據,解決方案:

     1.改變解析器類型爲:萬能解析器 ---> 手動解析JSON

        manager.responseSerializer = [AFHTTPResponseSerializer serializer];

     2.改變判斷條件的類型,以使類型匹配,acceptableContentTypes默認狀況下無 text/plain 類型

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

     注: 若是沒有使用第三方框架(CocoaPods)來管理第三方框架,能夠直接修改第三方框架的源代碼.

     通常在開發中,不要隨意修改第三方源碼.

2、AFHTTPRequestOperationManager的基本使用步驟:

1.建立管理者

AFHTTPRequestOperationManager *mgr = [AFHTTPRequestOperationManager manager];

2.封裝請求參數 

NSMutableDictionary *params = [NSMutableDictionary dictionary];
params[@"username"] = @"哈哈哈";
params[@"pwd"] = @"123";

3.發送請求

NSString *url = @"http://localhost:8080/Server/login";
[mgr POST:url parameters:params
  success:^(AFHTTPRequestOperation *operation, id responseObject) {
      // 請求成功的時候調用這個block
      NSLog(@"請求成功---%@", responseObject);
  } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
      // 請求失敗的時候調用調用這個block
      NSLog(@"請求失敗");
  }];
// GET請求
[mgr GET:url parameters:params
  success:^(AFHTTPRequestOperation *operation, id responseObject) {
      // 請求成功的時候調用這個block
      NSLog(@"請求成功---%@", responseObject);
  } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
      // 請求失敗的時候調用調用這個block
      NSLog(@"請求失敗");
  }];

 

3、對服務器返回數據的解析

1.AFN能夠自動對服務器返回的數據進行解析

* 默認將服務器返回的數據當作JSON來解析

 

2.設置對服務器返回數據的解析方式

1> 當作是JSON來解析(默認作法)

* mgr.responseSerializer = [AFJSONResponseSerializer serializer];

* responseObject的類型是NSDictionary或者NSArray

 

2> 當作是XML來解析

* mgr.responseSerializer = [AFXMLParserResponseSerializer serializer];

* responseObject的類型是NSXMLParser

 

3> 直接返回data

* 意思是:告訴AFN不要去解析服務器返回的數據,保持原來的data便可

* mgr.responseSerializer = [AFHTTPResponseSerializer serializer];

 

3.注意

* 服務器返回的數據必定要跟responseSerializer對得上

1> 服務器返回的是JSON數據

* AFJSONResponseSerializer

* AFHTTPResponseSerializer

 

2> 服務器返回的是XML數據

* AFXMLParserResponseSerializer

* AFHTTPResponseSerializer

 

3> 服務器返回的是其餘數據

* AFHTTPResponseSerializer

 

4、實時監測網絡狀態

可利用 AFN 實時監測網絡狀態.

AFNetworkReachabilityManager 實時檢測網絡狀態改變的類

AFNetworkReachabilityManager *manager = [AFNetworkReachabilityManager sharedManager];

// 設置網絡狀態改變以後的操做
[manager setReachabilityStatusChangeBlock:^(AFNetworkReachabilityStatus status) {
    
    // status :當前的網絡狀態.
    //        AFNetworkReachabilityStatusUnknown
    //        AFNetworkReachabilityStatusNotReachable
    //        AFNetworkReachabilityStatusReachableViaWWAN
    //        AFNetworkReachabilityStatusReachableViaWiFi
    
    switch (status) {
        case AFNetworkReachabilityStatusUnknown:
            
            NSLog(@"未知的網絡狀態");
            
            break;
            
        case AFNetworkReachabilityStatusNotReachable:
            
            NSLog(@"沒有網絡");
            
            break;
            
        case AFNetworkReachabilityStatusReachableViaWWAN:
            
            NSLog(@"蜂窩移動網絡");
            
            break;
            
        case AFNetworkReachabilityStatusReachableViaWiFi:
            
            NSLog(@"WIFI網絡");
            
            break;
            
        default:
            break;
    }
    
}];
// 開始檢測網絡狀態
[manager startMonitoring];

 

5、支持 HTTPS 網絡安全傳輸協議下的訪問

HTTPS = HTTP(超文本傳輸協議) + SSL (安全鏈接層) HTTP 的安全版本.

 

HTTPS 會專門創建一個 安全的數據傳輸通道來傳輸數據,外界拿不到任何數據,現階段最安全的協議,目前在 http 模式下三大運營商發送的惡意廣告氾濫,而且能夠得到用戶的我的信息,知乎有專門文章講解如何到工信部投訴的內容。

 

HTTPS 須要數字驗證,目前不少大公司使用的數字驗證都是默認支持的.

[manager GET:@"https://mail.itcast.cn" parameters:nil progress:^(NSProgress * _Nonnull downloadProgress) {
    //
} success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {
    
    NSData *data = responseObject;
    //
    NSLog(@"成功:%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]);
    
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
    //
    NSLog(@"失敗:%@",error);
}];

AFN 默認狀況下就是支持 HTTPS 訪問的,可是若是用 HTTPS 的方式訪問未受信任的網站便會報錯,解決方案:

修改對 SSL 的檢測:

AFN3.0以前:

manager.securityPolicy.allowInvalidCertificates = YES;

 

AFN3.0以後:

manager.securityPolicy.validatesDomainName = NO;

 

 


3、AFN和ASI的區別

1、底層實現

1> AFN的底層基於OC的NSURLConnection和NSURLSession

2> ASI的底層基於純C語言的CFNetwork框架

3> ASI的運行性能 高於 AFN

 

2、對服務器返回的數據處理

1> ASI沒有直接提供對服務器數據處理的方式,直接返回data\string

2> AFN提供了多種對服務器數據處理的方式

* JSON處理

* XML處理

* 其餘處理

 

3、監聽請求的過程

1> AFN提供了success和failure兩個block來監聽請求的過程(只能監聽成功和失敗)(3.0之後添加了進度)

* success : 請求成功後調用

* failure : 請求失敗後調用

 

2> ASI提供了3套方案,每一套方案都能監聽請求的完整過程

(監聽請求開始、接收到響應頭信息、接受到具體數據、接受完畢、請求失敗)

* 成爲代理,遵照協議,實現協議中的代理方法

* 成爲代理,不遵照協議,自定義代理方法

* 設置block

 

4、在文件下載和文件上傳的使用難易度

1> AFN

* 不容易監聽下載進度和上傳進度

* 不容易實現斷點續傳

* 通常只用來下載不大的文件

 

2> ASI

* 很是容易實現下載和上傳

* 很是容易監聽下載進度和上傳進度

* 很是容易實現斷點續傳

* 下載或大或小的文件都行

 

5、ASI提供了更多的實用功能

1> 控制圈圈要不要在請求過程當中轉

2> 能夠輕鬆地設置請求之間的依賴:每個請求都是一個NSOperation對象

3> 能夠統一管理全部請求(還專門提供了一個叫作ASINetworkQueue來管理全部的請求對象)

* 暫停\恢復\取消全部的請求

* 監聽整個隊列中全部請求的下載進度和上傳進度

相關文章
相關標籤/搜索