iOS开发之URLSession

1、概述

n  NSURLSession是iOS7中新的网络接口,与NSURLConnection是并列的。

n  当程序在前台时,NSURLSession与NSURLConnection大部分可以互相替代

n  NSURLSession支持后台网络操作,除非用户强行关闭

n  NSURLSession提供的功能:

p 通过URL将数据下载到内存

p 通过URL将数据下载到文件系统

p 将数据上传到指定URL

p 在后台完成上述功能

p 对于小型数据,例如用户登录、下载小图像、JSON & XML仍然使用NSURLConnection的异步或同步方法即可

2NSURLSession的使用

n  使用NSURLSessionConfiguration来配置NSURLSession对象

n  用NSURLSession对象来启动一个NSURLSessionTask对象

n  也可以使用系统全局的sharedSession单例来满足大多数的需求

n  注:相比较NSURLConnection的返回处理,NSURLSession提供了灵活的数据返回方式,可以使用简单的block方式来处理返回数据,也可以使用更强大的delegate

3NSURLSessionConfiguration

n  作用:用于定义和配置NSURLSession对象

n  每一个NSURLSession对象都可以设置不同的NSURLSessionConfiguration,从而满足应用内不同类型的网络请求

n  NSURLSessionConfiguration的三种类型:

(1) defaultSessionConfiguration默认session配置,类似NSURLConnection的标准配置,使用硬盘来存储缓存数据

(2) ephemeralSessionConfiguration临时session配置,与默认配置相比,这个配置不会将缓存、cookie等存在本地,只会存在内存里,所以当程序退出时,所有的数据都会消失

(3) backgroundSessionConfiguration后台session配置,与默认配置类似,不同的是会在后台开启另一个线程来处理网络数据

4NSURLSessionTask

n  NSURLSession使用NSURLSessionTask来具体执行网络请求的任务

n  NSURLSessionTask支持网络请求的取消、暂停和恢复,比如下载文件暂停之后再恢复就能够自动从上次的进度继续下载

n  NSURLSessionTask还能获取数据的读取进度

n  NSURLSessionTask的三种类型:

(1) NSURLSessionDataTask 处理一般的NSData数据对象,比如通过GET或POST方式从服务器获取JSON或XML返回等等,但不支持后台获取

(2) NSURLSessionUploadTask 用于上传文件,支持后台上传

(3) NSURLSessionDownloadTask 用于下载文件,支持后台下载

例如:

#pragma mark - 用Session上传头像

- (void)uploadFile

{

    // 1. NSURL

    NSString *urlString = @"http://localhost/uploads/测试一下.png";

    urlString = [urlString stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];

    NSURL *url = [NSURL URLWithString:urlString];

//    NSURL *url = [NSURL URLWithString:@"http://localhost/uploads/测试一下.png"];

   

    // 2. Request

    NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url cachePolicy:0 timeoutInterval:2.0];

   

    request.HTTPMethod = @"PUT";

   

    // 设置用户授权

    // 1> "admin:123456"

    NSString *authStr = @"admin:123456";

    // 2> result = 对字符串进行BASE64编码(网络传输中常用的一种编码格式,NSData)

    NSData *authData = [authStr dataUsingEncoding:NSUTF8StringEncoding];

    NSString *result = [authData base64EncodedStringWithOptions:0];

    // 3> "Basic result" => 提交给服务器的验证字符串,用来验证身份

    NSString *authString = [NSString stringWithFormat:@"Basic %@", result];

   

    // 设置HTTP请求头的数值,设置用户授权

    [request setValue:authString forHTTPHeaderField:@"Authorization"];

   

    // 3. Session,有一个单例,是全局共享的

    NSURLSession *session = [NSURLSession sharedSession];

   

    // 4. 文件上传

    NSURL *bundleURL = [[NSBundle mainBundle] URLForResource:@"头像1.png" withExtension:nil];

    // 所有任务默认都是挂起的

    NSURLSessionUploadTask *task = [session uploadTaskWithRequest:request fromFile:bundleURL completionHandler:^(NSData *data, NSURLResponse *response, NSError *error) {

       

        // 上传完成操作

        NSLog(@"%@", response);

    }];

   

    [task resume];

}

5通过HTTP PUT方法实现文件上传的步骤

n  实例化NSMutableURLRequest并指定HTTPMethod为PUT

n  设置请求的授权

(1) 授权字符串格式:用户名:口令

(2) 授权模式:Basic base64编码的授权字符串

(3) 为HTTPHeaderField的Authorization赋值

6文件上传的请求部分

// 1. URLRequest

NSURL *url = [NSURL URLWithString:@"http://localhost/uploads/xxx.png"];

NSMutableURLRequest *requestM = [NSMutableURLRequest requestWithURL:url cachePolicy:0 timeoutInterval:2.0f];

requestM.HTTPMethod = @"PUT";

// 设置用户授权

// 1> 授权字符串(用户名+密码)

NSString *authStr = @"admin:123456";

// 2> BASE 64编码

NSData *authData = [authStr dataUsingEncoding:NSUTF8StringEncoding];

NSString *base64Str = [authData base64EncodedStringWithOptions:0];

NSString *auth = [NSString stringWithFormat:@"BASIC %@", base64Str];

[requestM setValue:auth forHTTPHeaderField:@"Authorization"];

75HTTP的常见方法

GET         获取指定资源

POST      2M 向指定资源提交数据进行处理请求,在RESTful风格中用于新增资源

HEAD            获取指定资源头部信息

PUT        替换指定资源(不支持浏览器操作)

DELETE         删除指定资源

n  OPTIONS     允许客户端查看服务器的性能

n  TRACE           回显服务器收到的请求,主要用于测试或诊断

n  CONNECT    预留给能够将连接改为管道方式的代理服务器(HTTP代理使用)

n  提示:

  1. 鉴于安全方面的考虑,服务器大多不会开放所有的HTTP请求方法
  2. PUT和DELETE目前在国内使用不多,大多由POST取代,但是在iOS开发中PUT是最简单的实现文件上传的方式

 

转载于:https://www.cnblogs.com/lifengfneg/p/4774046.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值