进阶19 AFN(AFNetworking)

AFNetworking

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

AFNetworking设计思路

    1. 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 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提供了请求的安全策略。
    1. AFSecurityPolicy:评估服务器安全连接针对指定的固定证书或公共密钥的信任。将你的服务器证书添加到app bundle,以帮助防止中间人攻击。

你可能感兴趣的:(进阶19 AFN(AFNetworking))