AFNetworking
- AFNetworking是一个轻量级的iOS网络通信类库。
- 2.它建立在NSURLConnection和NSOperation等类库的基础上,让很多网络通信功能的实现变得十分简单。
- 3.它支持HTTP请求和基于REST的网络服务(包括GET、POST、PUT、DELETE等)。
- 4 支持ARC。
AFNetworking设计思路
- AFNetworking是基于NSURLConnection和NSOperation的
- 1.1 NSURLConnection是处理网络连接的。
- 1.2 NSOperation是管理NSURLConnection的,可以监听一个请求的生命周期。
NSOperation
- 1.NSURLConnectionOperation: NSOperation的子类,实现了NSURLConnection的代理方法。
- 2.AFHTTPRequestOperation:NSURLConnectionOperation的子类,针对request使用的协议为HTTP和HTTPS。
- 3.AFHTTPRequestOperationManager:封装了一组调用请求的方法。
#pragma mark --- GET请求 ---
- (void)GET{
//创建manager请求对象
AFHTTPRequestOperationManager *mgr = [AFHTTPRequestOperationManager manager];
[mgr GET:@"http://api.douban.com/v2/event/list?type=all&district=all&loc=108288&photo_cate=image&photo_count=1&start=3&day_type=future&apikey=062bcf31694a52d212836d943bdef876" parameters:nil success:^(AFHTTPRequestOperation *operation, id responseObject) {
//responseObject里面,是请求成功以后返回的字典或者数组,然后对其进行解析
NSLog(@"GET请求成功:%@",responseObject);
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
NSLog(@"GET请求失败:%@",error);
}];
}
#pragma mark --- POST请求 ---
- (void)POST{
//创建manager请求对象
AFHTTPRequestOperationManager *mgr = [AFHTTPRequestOperationManager manager];
//设置请求的参数为JSON格式
mgr.requestSerializer = [AFJSONRequestSerializer serializer];
//设置响应序列化为二进制
mgr.responseSerializer = [AFHTTPResponseSerializer serializer];
//设置一个body
NSDictionary *dic = @{@"date":@"20131129",@"startRecord":@"1",@"len":@"5",@"udid":@"1234567890",@"terminalType":@"Iphone",@"cid":@"213"};
[mgr POST:@"http://ipad-bjwb.bjd.com.cn/DigitalPublication/publish/Handler/APINewsList.ashx" parameters:dic success:^(AFHTTPRequestOperation *operation, id responseObject) {
NSLog(@"POST请求成功:%@",responseObject);
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
NSLog(@"POST请求失败:%@",error);
}];
[mgr POST:@"" parameters:nil constructingBodyWithBlock:^(id<AFMultipartFormData> formData) {
} success:^(AFHTTPRequestOperation *operation, id responseObject) {
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
}];
}
iOS7.0以上的系统
如果是iOS7.0以上的系统,AFNetworking提供了更高级的方法,如下:
- 1.AFURLSessionManager:创建、管理基于NSURLSessionConfiguration对象的NSURLSession对象的类,也可以管理session的数据、下载/上传任务,实现session和其相关联的任务的delegate方法。
- 2.AFHTTPSessionManager:封装了一组调用请求的方法。
#pragma mark --- 文件下载 ---
- (void)download{
//创建一个用来分别配置每一个session对象的类,defaultSessionConfiguration:是session的默认配置,表示的是使用硬盘来存储缓存数据
NSURLSessionConfiguration *Configuration = [NSURLSessionConfiguration defaultSessionConfiguration];
//创建manager管理对象
AFURLSessionManager *mgr = [[AFURLSessionManager alloc] initWithSessionConfiguration:Configuration];
//下载内容的接口
NSURL *url = [NSURL URLWithString:@"https://codeload.github.com/tonymillion/Reachability/zip/master"];
//创建请求
NSURLRequest *request = [NSURLRequest requestWithURL:url];
//创建下载任务
NSURLSessionDownloadTask *task = [mgr downloadTaskWithRequest:request progress:nil destination:^NSURL *(NSURL *targetPath, NSURLResponse *response) {
//该block需要返回值
NSURL *path = [[NSFileManager defaultManager]URLForDirectory:NSDocumentDirectory inDomain:NSUserDomainMask appropriateForURL:nil create:NO error:nil];
//返回和服务器文件名一样,当我们希望保存到文件名和服务器的文件名一致时,可以使用这个名字:suggestedFilename
return [path URLByAppendingPathComponent:[response suggestedFilename]];
} completionHandler:^(NSURLResponse *response, NSURL *filePath, NSError *error) {
//打印下载后的存储路径
NSLog(@"文件下载了:%@",filePath);
}];
//执行任务
[task resume];
}
#pragma mark ---文件上传 ---
- (void)upLoad{
//创建一个用来分别配置每一个session对象的类,defaultSessionConfiguration:是session的默认配置,表示的是使用硬盘来存储缓存数据
NSURLSessionConfiguration *Configuration = [NSURLSessionConfiguration defaultSessionConfiguration];
//创建manager管理对象
AFURLSessionManager *mgr = [[AFURLSessionManager alloc] initWithSessionConfiguration:Configuration];
//将东西上传到的接口
NSURL *url = [NSURL URLWithString:@""];
//创建请求
NSURLRequest *request = [NSURLRequest requestWithURL:url];
//将要上传文件路径
NSURL *path = [NSURL URLWithString:@"usr/../...zip"];
//创建上传任务
NSURLSessionUploadTask *task = [mgr uploadTaskWithRequest:request fromFile:path progress:nil completionHandler:^(NSURLResponse *response, id responseObject, NSError *error) {
if (error) {
NSLog(@"上传失败:%@",error);
}else{
NSLog(@"上传成功%@ ___________ %@",response,responseObject);
}
}];
//执行任务
[task resume];
}
针对请求和相应的序列化
AFNetworking针对请求和响应的序列化进行的单独的封装,如下:
- 1.AFURLRequestSerialzation:符合这个协议的对象用于处理请求,它将请求参数转换为 query string 或是 entity body 的形式,并设置必要的header。
- 2.AFURLResponseSerialzation:符合这个协议的对象用于验证、序列化响应及相关数据,转换为有用的形式,比如JSON对象、图像、甚至基于Mantle的模型对象。
检测当前网络的可达性
AFNetworking可以检测当前网络的可达性。
- 1.AFNetworkReachabilityManager:这个类监控当前网络的可达性,提供回调 block 和 notification,在可达性变化时调用。
#pragma mark --- 网络判断 ---
- (void)reachability{
//创建网络监听管理者对象
AFNetworkReachabilityManager *mgr = [AFNetworkReachabilityManager sharedManager];
[mgr setReachabilityStatusChangeBlock:^(AFNetworkReachabilityStatus status) {
switch (status) {
case AFNetworkReachabilityStatusUnknown:
NSLog(@"未识别的网络");
break;
case AFNetworkReachabilityStatusReachableViaWiFi:
NSLog(@"wifi网络");
break;
case AFNetworkReachabilityStatusNotReachable:
NSLog(@"不可达的(未连接的)");
break;
case AFNetworkReachabilityStatusReachableViaWWAN:
NSLog(@"2G,3G,4G网络");
break;
default:
break;
}
}];
//开始监听
[mgr startMonitoring];
}
提供了请求的安全策略
AFNetworking提供了请求的安全策略。
- AFSecurityPolicy:评估服务器安全连接针对指定的固定证书或公共密钥的信任。将你的服务器证书添加到app bundle,以帮助防止中间人攻击。
网友评论