首先介紹一下AFNetworking的基本情況
AFNetworking是一款在OS X和iOS下都令人喜愛的網(wǎng)絡(luò)庫。為了迎合iOS新版本的升級, AFNetworking在3.0版本中刪除了基于 NSURLConnection API的所有支持塑荒。如果你的項(xiàng)目以前使用過這些API熄赡,建議您立即升級到基于 NSURLSession 的API的AFNetworking的版本。本指南將引導(dǎo)您完成這個(gè)過程齿税。
本指南是為了引導(dǎo)使用AFNetworking 2.x升級到最新的版本API彼硫,以達(dá)到過渡的目的,并且解釋了新增和更改的設(shè)計(jì)結(jié)構(gòu)凌箕。
新設(shè)備要求: iOS 7, Mac OS X 10.9, watchOS 2, tvOS 9, & Xcode 7
AFNetworking 3.0正式支持的iOS 7拧篮, Mac OS X的10.9, watchOS 2 牵舱, tvOS 9 和Xcode 7串绩。如果你想使用AFNetworking在針對較舊版本的SDK項(xiàng)目,請檢查README的兼容性信息芜壁。
NSURLConnection的API已廢棄
AFNetworking 1.0建立在NSURLConnection的基礎(chǔ)API之上 礁凡,AFNetworking 2.0開始使用NSURLConnection的基礎(chǔ)API ,以及較新基于NSURLSession的API的選項(xiàng)慧妄。 AFNetworking 3.0現(xiàn)已完全基于NSURLSession的API顷牌,這降低了維護(hù)的負(fù)擔(dān),同時(shí)支持蘋果增強(qiáng)關(guān)于NSURLSession提供的任何額外功能塞淹。由于Xcode 7中窟蓝,NSURLConnection的API已經(jīng)正式被蘋果棄用。雖然該API將繼續(xù)運(yùn)行窖铡,但將沒有新功能將被添加疗锐,并且蘋果已經(jīng)通知所有基于網(wǎng)絡(luò)的功能坊谁,以充分使NSURLSession向前發(fā)展。
AFNetworking 2.X將繼續(xù)獲得關(guān)鍵的隱患和安全補(bǔ)丁滑臊,但沒有新的功能將被添加口芍。Alamofire(Swift下的網(wǎng)絡(luò)請求)件基金會建議,所有的項(xiàng)目遷移到基于NSURLSession的API雇卷。
棄用的類
下面的類已從AFNetworking 3.0中廢棄:
AFURLConnectionOperation
AFHTTPRequestOperation
AFHTTPRequestOperationManager
修改的類
下面的類包含基于NSURLConnection的API的內(nèi)部實(shí)現(xiàn)鬓椭。他們已經(jīng)被使用NSURLSession重構(gòu):
UIImageView+AFNetworking
UIWebView+AFNetworking
UIButton+AFNetworking
遷移
AFHTTPRequestOperationManager 核心代碼
如果你以前使用 AFHTTPRequestOperationManager , 你將需要遷移去使用 AFHTTPSessionManager关划。 以下的類在兩者過渡間并沒有變化:
securityPolicy
requestSerializer
responseSerializer
接下來舉一個(gè)關(guān)于AFHTTPSessionManager的簡單例子小染。注意HTTP網(wǎng)絡(luò)請求返回的不再是AFHTTPRequestOperation, 修改成為了NSURLSessionTask,并且成功和失敗的Block塊中的參數(shù)也變更為了NSURLSessionTask贮折,而不再是AFHTTPRequestOperation裤翩。
AFNetworking 2.x
AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
[manager GET:@"請求的url" parameters:nil success:^(AFHTTPRequestOperation *operation, id responseObject) {
NSLog(@"成功");
} failure:^(AFHTTPRequestOperation *operation, NSError*error) {
NSLog(@"失敗");
}];
AFNetworking 3.0
AFHTTPSessionManager *session = [AFHTTPSessionManager manager];
[session GET:@"請求的url" parameters:nil success:^(NSURLSessionDataTask *task, id responseObject) {
NSLog(@"成功");
} failure:^(NSURLSessionDataTask *task, NSError *error) {
NSLog(@"失敗");
}];
AFHTTPRequestOperation 核心代碼
與NSURLConnection對象不同,每個(gè)共享應(yīng)用范圍的設(shè)置如會話管理调榄、緩存策略踊赠、Cookie存儲以及URL協(xié)議等,這些NSURLSession對象都可以單獨(dú)進(jìn)行配置每庆。使用特定的配置來初始化會話筐带,它可以發(fā)送任務(wù)來獲取數(shù)據(jù),并上傳或下載文件缤灵。
在AFNetworking 2.0中伦籍,使用AFHTTPRequestOperation,有可能創(chuàng)建一個(gè)沒有額外開銷的獨(dú)立的網(wǎng)絡(luò)請求來獲取數(shù)據(jù)腮出。NSURLSession則需要更多的開銷帖鸦,為了獲得所要請求的數(shù)據(jù)。
接下來利诺,將要通過AFHTTPSessionManager創(chuàng)建一個(gè)單例富蓄,并創(chuàng)建一個(gè)任務(wù)和啟動它剩燥。
AFNetworking 2.x
NSURL *URL = [NSURL URLWithString:@""];
NSURLRequest *request = [NSURLRequest requestWithURL:URL];
AFHTTPRequestOperation *op = [[AFHTTPRequestOperation alloc] initWithRequest:request];
op.responseSerializer = [AFJSONResponseSerializer serializer];
[op setCompletionBlockWithSuccess:^(AFHTTPRequestOperation *operation, id responseObject) {
NSLog(@"JSON: %@", responseObject);
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
NSLog(@"Error: %@", error);
}];
[[NSOperationQueue mainQueue] addOperation:op];
AFNetworking 3.0
NSURL *URL = [NSURL URLWithString:@""];
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
[manager GET:URL.absoluteString parameters:nil success:^(NSURLSessionTask *task, id responseObject) {
NSLog(@"JSON: %@", responseObject);
} failure:^(NSURLSessionTask *operation, NSError *error) {
NSLog(@"Error: %@", error);
}];
UIKit的遷移
圖片下載已經(jīng)被重構(gòu)慢逾,以遵循AlamofireImage架構(gòu)與新的AFImageDownloader類。這個(gè)類的圖片下載職責(zé)的代理人是UIButton與UIImageView的類目灭红,并且提供了一些方法侣滩,在必要時(shí)可以自定義。類別中变擒,下載遠(yuǎn)程圖片的實(shí)際方法沒有改變君珠。
UIWebView的類目被重構(gòu)為使用AFHTTPSessionManager作為其網(wǎng)絡(luò)請求。
UIAlertView的類目被廢棄
從AFNetworking 3.0后UIAlertView的類目因過時(shí)而被廢棄娇斑。并沒有提供UIAlertController類目的計(jì)劃策添,因?yàn)檫@是應(yīng)用程序應(yīng)處理的邏輯材部,而不是這個(gè)庫。
以上是對AFNetworking基本使用的一些資料唯竹!下面來說一說AFNetworking的基本使用
手下你說一說AFNetworking的get和post請求乐导,代碼如下
getRequest
//1.創(chuàng)建會話管理者
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
//http://120.25.226.186:32812/login?username=123&pwd=122&type=JSON
//
NSDictionary *paramDict = @{
@"username":@"dandan",
@"pwd":@"dandan",
@"type":@"JSON"
};
//2.發(fā)送GET請求
/*
第一個(gè)參數(shù):請求路徑(不包含參數(shù)).NSString
第二個(gè)參數(shù):字典(發(fā)送給服務(wù)器的數(shù)據(jù)~參數(shù))
第三個(gè)參數(shù):progress 進(jìn)度回調(diào)
第四個(gè)參數(shù):success 成功回調(diào)
task:請求任務(wù)
responseObject:響應(yīng)體信息(JSON--->OC對象)
第五個(gè)參數(shù):failure 失敗回調(diào)
error:錯(cuò)誤信息
響應(yīng)頭:task.response
*/
[manager GET:@"http://168.192.1.18:33322/login" parameters:paramDict progress:nil success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
NSLog(@"%@---%@",[responseObject class],responseObject);
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
NSLog(@"請求失敗--%@",error);
}];
postRequest
//1.創(chuàng)建會話管理者
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
NSDictionary *paramDict = @{
@"username":@"dandan",
@"pwd":@"dandan",
@"type":@"JSON"
};
//2.發(fā)送GET請求
/*
第一個(gè)參數(shù):請求路徑(不包含參數(shù)).NSString
第二個(gè)參數(shù):字典(發(fā)送給服務(wù)器的數(shù)據(jù)~參數(shù))
第三個(gè)參數(shù):progress 進(jìn)度回調(diào)
第四個(gè)參數(shù):success 成功回調(diào)
task:請求任務(wù)
responseObject:響應(yīng)體信息(JSON--->OC對象)
第五個(gè)參數(shù):failure 失敗回調(diào)
error:錯(cuò)誤信息
響應(yīng)頭:task.response
*/
[manager POST:@"http://168.192.1.18:33322/login" parameters:paramDict progress:nil success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
NSLog(@"%@---%@",[responseObject class],responseObject);
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
NSLog(@"請求失敗--%@",error);
}];
上面是把AFNetworking的get和post請求列舉了一下!下面說一下它一些高級的使用
使用AFNetworking下載文件浸颓,廢話不多說直接上代碼
//1.創(chuàng)建會話管理者
AFHTTPSessionManager *manager =[AFHTTPSessionManager manager];
NSURL *url = [NSURL URLWithString:@"http://168.192.1.18:33322/resources/videos/minion_01.mp4"];
NSURLRequest *request = [NSURLRequest requestWithURL:url];
//2.下載文件
/*
第一個(gè)參數(shù):請求對象
第二個(gè)參數(shù):progress 進(jìn)度回調(diào) downloadProgress
第三個(gè)參數(shù):destination 回調(diào)(目標(biāo)位置)
有返回值
targetPath:臨時(shí)文件路徑
response:響應(yīng)頭信息
第四個(gè)參數(shù):completionHandler 下載完成之后的回調(diào)
filePath:最終的文件路徑
*/
NSURLSessionDownloadTask *download = [manager downloadTaskWithRequest:request progress:^(NSProgress * _Nonnull downloadProgress) {
//監(jiān)聽下載進(jìn)度
//completedUnitCount 已經(jīng)下載的數(shù)據(jù)大小
//totalUnitCount 文件數(shù)據(jù)的中大小
NSLog(@"%f",1.0 *downloadProgress.completedUnitCount / downloadProgress.totalUnitCount);
} destination:^NSURL * _Nonnull(NSURL * _Nonnull targetPath, NSURLResponse * _Nonnull response) {
NSString *fullPath = [[NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:response.suggestedFilename];
NSLog(@"targetPath:%@",targetPath);
NSLog(@"fullPath:%@",fullPath);
return [NSURL fileURLWithPath:fullPath];
} completionHandler:^(NSURLResponse * _Nonnull response, NSURL * _Nullable filePath, NSError * _Nullable error) {
NSLog(@"%@",filePath);
}];
//3.執(zhí)行Task
[download resume];
執(zhí)行上面的代碼就可以實(shí)現(xiàn)基本的網(wǎng)絡(luò)下載數(shù)據(jù) 物臂。
上面說完AFNetworking的文件下載,我們再說一下文件上傳产上。下面上代碼棵磷!
這種方法不推薦,下面另外會介紹幾種不一樣的方法晋涣!
// 這種方法不推薦仪媒,再使用的過程中 使用過程中泰繁瑣! 下面會推薦另一種方法谢鹊!
//1.創(chuàng)建會話管理者
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
//2.1url
NSURL *url = [NSURL URLWithString:@"http://168.192.1.18:33322/upload"];
//2.2創(chuàng)建請求對象
NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url];
//2.3 設(shè)置請求方法
request.HTTPMethod = @"POST";
//2.4 設(shè)請求頭信息 這個(gè)請求頭信息必須要設(shè)置规丽。
[request setValue:[NSString stringWithFormat:@"multipart/form-data; boundary=%@",Kboundary] forHTTPHeaderField:@"Content-Type"];
//3.發(fā)送請求上傳文件
NSURLSessionUploadTask *uploadTask = [manager uploadTaskWithRequest:request fromData:[self getBodyData] progress:^(NSProgress * _Nonnull uploadProgress) {
NSLog(@"%f",1.0 * uploadProgress.completedUnitCount/ uploadProgress.totalUnitCount);
} completionHandler:^(NSURLResponse * _Nonnull response, id _Nullable responseObject, NSError * _Nullable error) {
NSLog(@"%@",responseObject);
}];
//4.執(zhí)行task
[uploadTask resume];
下面是另一種方法進(jìn)行上傳文件
//1.創(chuàng)建會話管理者
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
// NSDictionary *dictM = @{}
//2.發(fā)送post請求上傳文件
/*
第一個(gè)參數(shù):請求路徑
第二個(gè)參數(shù):字典(非文件參數(shù))
第三個(gè)參數(shù):constructingBodyWithBlock 處理要上傳的文件數(shù)據(jù)
第四個(gè)參數(shù):進(jìn)度回調(diào)
第五個(gè)參數(shù):成功回調(diào) responseObject:響應(yīng)體信息
第六個(gè)參數(shù):失敗回調(diào)
*/
[manager POST:@"http://168.192.1.18:33322/upload" parameters:nil constructingBodyWithBlock:^(id<AFMultipartFormData> _Nonnull formData) {
UIImage *image = [UIImage imageNamed:@"Snip20160227_128"];
NSData *imageData = UIImagePNGRepresentation(image);
//使用formData來拼接數(shù)據(jù)
/*
第一個(gè)參數(shù):二進(jìn)制數(shù)據(jù) 要上傳的文件參數(shù)
第二個(gè)參數(shù):服務(wù)器規(guī)定的
第三個(gè)參數(shù):該文件上傳到服務(wù)器以什么名稱保存
*/
//[formData appendPartWithFileData:imageData name:@"file" fileName:@"xxxx.png" mimeType:@"image/png"];
//[formData appendPartWithFileURL:[NSURL fileURLWithPath:@"/Users/Da/Desktop/Snip20160227_128.png"] name:@"file" fileName:@"123.png" mimeType:@"image/png" error:nil];
[formData appendPartWithFileURL:[NSURL fileURLWithPath:@"/Users/xiaomage/Desktop/Snip20160227_128.png"] name:@"file" error:nil];
} progress:^(NSProgress * _Nonnull uploadProgress) {
NSLog(@"%f",1.0 * uploadProgress.completedUnitCount/uploadProgress.totalUnitCount);
} success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
NSLog(@"上傳成功---%@",responseObject);
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
NSLog(@"上傳失敗---%@",error);
}];