美文网首页iOS 小册
[iOS-Foundation] NSURLSessionCon

[iOS-Foundation] NSURLSessionCon

作者: 水止云起 | 来源:发表于2016-09-22 09:43 被阅读800次

    NSURLSessionConfiguration 定义了NSURLSession中网络请求的行为和策略,如超时时间、缓存策略等。当使用NSURLSessionConfiguration对象创建NSURL�Session对象时,会使用NSURLSessionConfiguration对象的一份拷贝,而之后对原NSURLSessionConfiguration对象的修改则不会影响NSURLSession对象。若要修改则只能用更改后的NSURLSessionConfiguration对象重新创建新的NSURLSession对象。需要注意的是,NSURLSessionConfiguration中的某些设置可能会被NSURLSessionTask的 request 覆盖。

    普通配置项

    • identifier,用于唯一标识一个后台下载的 session,当系统重启被自动关闭的应用时,可以通过这个标识符,重新创建 configuration 和 session 对象来恢复中断的下载。
    • HTTPAdditionalHeaders,一个 dictionary,包含了需要额外添加到 session 中所有 request 的 header,如User-Agent。不应添加
      AuthorizationConnectionHostWWW-Authenticate。如果 request 中已存在某一 header,则使用 request 中的值,该 dictionary 默认为空。
    • networkServiceTypeNSURLRequestNetworkServiceType类型,network service type 影响着操作系统对于网络传输的优先级排列,进而影响系统电量、性能的消耗。默认值是NSURLNetworkServiceTypeDefault
    • allowsCellularAccess,布尔值,指明在移动网络下是否可发起请求。
    • timeoutIntervalForRequest,请求的超时时间,默认值为60秒。
    • timeoutIntervalForResource,所有资源下载或上传完成的超时时间,中间请求失败可重新请求,单位为秒,默认时间为7天。
    • sharedContainerIdentifier,用于应用扩展与应用间的后台会话的扩展容器。

    HTTP cookie 相关配置项

    • HTTPCookieAcceptPolicy,接收 cookie 的策略,
      NSHTTPCookieAcceptPolicy类型,默认值是
      NSHTTPCookieAcceptPolicyOnlyFromMainDocumentDomain
    • HTTPCookieStorage,对于default 和 background session,该属性值为NSHTTPCookieStorage的单例对象,而 ephemeral session 的默认值为一个私有的NSHTTPCookieStorage对象,只将 cookie 保存在内存中,如果 session 不想保存 cookie,可将该属性设为 nil。
    • HTTPShouldSetCookies,布尔值,指明请求时是否携带 cookie 信息。

    安全相关配置项

    • TLSMaximumSupportedProtocol,SSLProtocol 类型,请求支持的最高 TLS 版本,默认值是 kTLSProtocol12,即 TLS1.2。
    • TLSMinimumSupportedProtocol,SSLProtocol 类型,请求支持的最低 TLS 版本,默认值是 kSSLProtocol3,即 SSL3.0。
    • URLCredentialStorage,管理需要验证的请求证书。

    缓存策略配置项

    • URLCache,用于保存缓存响应的NSURLCache对象,default session 默认使用NSURLCache的单例对象,background session 的默认值为 nil,而 ephemeral session 的默认值是一个私有的NSURLCache对象,数据只保存在内存中。如果不想使用缓存,可直接设置该值为 nil。
    • requestCachePolicy,枚举类型NSURLRequestCachePolicy,指明了请求使用缓存响应的策略。
    // 默认值,使用协议本身的缓存逻辑。
    NSURLRequestUseProtocolCachePolicy
    // 不使用现有缓存,数据需要从原始地址加载。
    NSURLRequestReloadIgnoringLocalCacheData
    // 无论缓存是否过期,先使用本地缓存数据。如果缓存中没有请求所对应的数据,那么从原始地址加载数据。
    NSURLRequestReturnCacheDataElseLoad
    // 无论缓存是否过期,先使用本地缓存数据。如果缓存中没有请求所对应的数据,那么放弃从原始地址加载数据,请求视为失败。
    NSURLRequestReturnCacheDataDontLoad
    

    后台下载配置项

    • sessionSendsLaunchEvents,布尔值,说明在 session task 完成或者需要验证时,是否在后台运行应用。当设为 YES 时,系统会自动启动或运行应用,并调用 AppDelegate 中的方法
      application:handleEventsForBackgroundURLSession:completionHandler:,通过参数提供上述提到的唯一标识后台下载 session 的 identifier。
    • discretionary,布尔值,说明在下载时是否由系统统一安排资源。

    自定义协议配置项

    • protocolClasses,由自定义实现的NSURLProtocol子类的 Class 对象组成的数组,配置了 session 支持的自定义协议。

    HTTP相关配置项

    • HTTPMaximumConnectionsPerHost,session 内一个域名的最大同时连接数。
    • HTTPShouldUsePipelining,布尔值,说明 session 内的 task 是否使用 HTTP pipelining。
    • connectionProxyDictionary,字典类型,保存了连接代理的相关信息,默认为 NULL。

    内置的配置对象

    通过类方法,NSURLSessionConfiguration提供了适用于不同情况的配置对象,它们的一些配置属性设置了不同的默认值。

    • + defaultSessionConfiguration,默认的配置对象,持久化存储缓存,证书,cookie。
    • + ephemeralSessionConfiguration,不持久化存储缓存,证书,cookie的配置。所有相关内容只保存在内存中,当 session 失效或应用终止,所有内容被清空。该配置可提高私密性,因为不会向硬盘上写入数据。
    • + backgroundSessionConfigurationWithIdentifier:,适用于在后台上传和下载文件的网络请求。当应用被系统终止并重启,传入的参数 identifier 可用来重新创建配置和 session 对象,以便恢复中断的下载任务。如果是用户主动终止程序,则不会有上述行为。

    相关文章

      网友评论

      • JackYao:是否可以转载? :blush:
        JackYao:@二巷小鞭 thanks~ 整理一波 会标注原作者的
        水止云起:@JackYao 当然可以 :blush:
      • 可可_running:说的挺明白,但是看了一遍还是很懵,能不能给推荐一本介绍网络这一块的书呢!thanks!
        水止云起:@可可_running 文章基本就是把 NSURLSessionConfiguration 类的文档简单翻了一下,方便日后快速翻看查找用的。如果是想了解原生网络层框架的话,当然是看官方文档啦,https://developer.apple.com/library/content/documentation/Cocoa/Conceptual/URLLoadingSystem/URLLoadingSystem.html,跟着这份 guide 文档,就可以了解整个 iOS 原生 URL Loading System。当然还包括其他几篇网络编程的文档,这里有连接 http://www.jianshu.com/p/a5251d9ee5c0

      本文标题:[iOS-Foundation] NSURLSessionCon

      本文链接:https://www.haomeiwen.com/subject/nnqoettx.html