AFNetworking的简单使用

本文意义

  • 直接用代码演示了AFNetworking框架的基本用法
  • 利用AFN发送GET、POST请求、文件上传等
  • 本文以下代码测试的服务器是虚作的,如果真想在远程服务器测试,可以留言

什么是AFN

  • 全称是AFNetworking,流行框架,在iOS开发中,使用比较广泛
  • AFN的github地址
    https://github.com/pokeb/AFNetworking/AFNetworking

AFN发送GET请求, 直接上代码,注意看注释

  • AFHTTPSessionManager内部包装了NSURLSession
  • 不用在URL后面拼接参数,传入一个参数数据就可以了
  • 默认采用JSON解析了服务器响应的数据
- (void)get
{
    // AFHTTPSessionManager内部包装了NSURLSession
    AFHTTPSessionManager *mgr = [AFHTTPSessionManager manager];

    NSDictionary *params = @{
                             @"username" : @"123",
                             @"pwd" : @"123"
                             };

    [mgr GET:@"http://www.baidu.com/login" parameters:params success:^(NSURLSessionDataTask *task, id responseObject) {
        NSLog(@"请求成功---%@", responseObject);
    } failure:^(NSURLSessionDataTask *task, NSError *error) {
        NSLog(@"请求失败---%@", error);
    }];
}

AFN发送POST请求

  • 只要将GET改为POST即可,其它跟GET请求一样
- (void)get
{
    // AFHTTPSessionManager内部包装了NSURLSession
    AFHTTPSessionManager *mgr = [AFHTTPSessionManager manager];

    NSDictionary *params = @{
                             @"username" : @"123",
                             @"pwd" : @"123"
                             };

    [mgr POST:@"http://www.baidu.com/login" parameters:params success:^(NSURLSessionDataTask *task, id responseObject) {
        NSLog(@"请求成功---%@", responseObject);
    } failure:^(NSURLSessionDataTask *task, NSError *error) {
        NSLog(@"请求失败---%@", error);
    }];
}

AFN上传文件

  • 上传文件,AFN做了非常好的封装,建议以后采用AFN来上传文件,当然如果你想学习上传文件的底层代码,可以浏览我另一篇博文------文件上传
- (void)upload{

    AFHTTPSessionManager *mgr = [AFHTTPSessionManager manager];
    [mgr POST:@"http://www.baidu.com/upload"  parameters:nil constructingBodyWithBlock:^(id formData) {

        // 这是最简单的版本,只要设置请求的URL、给出文件路径和name,便可将文件上传到服务器,后面有代码介绍其它方式
        [formData appendPartWithFileURL:[NSURL fileURLWithPath:@"/Users/zhamengjun/Desktop/Swift Programming Language.epub"] name:@"file" error:nil];

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

        // 文件上传成功来到这段代码,注意responseObject的实际类型,AFN默认解析过
        NSLog(@"------%@", responseObject);

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

        NSLog(@"failure");
    }];
}
  • 常规的方式上传文件,需要指定URL、文件名、文件的MIMEType、name,上面的方式,只是AFN根据请求的URL,默认获取了文件名和文件的MIMEType
  • 关于如何获取文件的MIMEType,请关注另一篇博文:获取文件的MIMEType

    //创建data对象
    NSData *data = [NSData dataWithContentsOfURL:[NSURL fileURLWithPath:@"/Users/zhamengjun/Desktop/Swift Programming Language.epub"]];

    // 上传书籍文件
        [formData appendPartWithFileData:data name:@"file" fileName:@"Swift Programming Language.epub" mimeType:@"application/epub+zip"];

    // 上传图片实例
        [formData appendPartWithFileData:data name:@"file" fileName:@"Snip20150715_1.png" mimeType:@"image/png"];

通过AFN设置服务器响应数据的解析方式

  • 默认情况下,AFN采用以下方式解析服务器响应的数据
    // 解析服务器返回的JSON数据
    [AFJSONResponseSerializer serializer];
  • 其它常用的解析方式
    // 直接使用“服务器本来返回的数据”,不做任何解析
    [AFHTTPResponseSerializer serializer];

    // 解析服务器返回的XML数据
    [AFXMLParserResponseSerializer serializer];
  • 具体采用哪种解析方式,看客户端向服务器请求数据的类型

    • 如果请求的是图片,[AFHTTPResponseSerializer serializer];
    • 如果请求的是XML数据类型 [AFXMLParserResponseSerializer serializer];
    • 如果是JSON,就采用系统默认的做法
  • 实例代码

- (void)xml
{
    AFHTTPSessionManager *mgr = [AFHTTPSessionManager manager];

    // responseSerializer 用来解析服务器返回的数据

    // 告诉AFN,以XML形式解析服务器返回的数据
    mgr.responseSerializer = [AFXMLParserResponseSerializer serializer];

    NSDictionary *params = @{
                             @"username" : @"123",
                             @"pwd" : @"123",
                             @"type" : @"XML"
                             };

    // 如果明确知道服务器返回数据的类型,可以直接将id改为NSXMLParser *parser
    [mgr GET:@"http://www.baidu.com/login" parameters:params success:^(NSURLSessionDataTask *task, NSXMLParser *parser) {

    } failure:^(NSURLSessionDataTask *task, NSError *error) {
        NSLog(@"请求失败---%@", error);
    }];
}

你可能感兴趣的:(AFNetworking的简单使用)