NSURLSessionConfiguration的描述

一、NSURLSessionConfiguration的描述

NSURLSessionConfiguration为NSURLSession配置一些请求所需要的策略。如:超时、缓存策略、链接需求的。

NSURLSession会 拷贝configuration。所以session一旦初始化结束就不会再更改configuration。除非初始化一个session。

重要:如果NSURLRequest中也做了一些指定。session也会遵循NSURLRequest的限定,但是如果configuration有更加严格的限定,仍以configuration 为主


二、 defaultSessionConfiguration  
默认配置使用的是持久化的硬盘缓存,存储证书到用户钥匙链。存储cookie到shareCookie。

标注:如果想要移植原来基于NSURLConnect的代码到NSURLSession,可使用该默认配置,然后再根据需要定制该默认配置。


三、 ephemeralSessionConfiguration  
返回一个不适用永久持存cookie、证书、缓存的配置,最佳优化数据传输。
标注:当程序作废session时,所有的ephemeral session 数据会立即清除。此外,如果你的程序处于暂停状态,内存数据可能不会立即清除,但是会在程序终止或者收到内存警告或者内存压力时立即清除

四、 backgroundSessionConfigurationWithIdentifier  
生成一个可以上传下载HTTP和HTTPS的后台任务(程序在后台运行)。
在后台时,将网络传输交给系统的单独的一个进程。

重要:identifier 是configuration的唯一标示,不能为空或nil.

工作状态:
如果程序是被系统正常终止的和重新启动,可以使用同一个 identifier创建configuration和session,并且能恢复终止时的传输状态。
如果程序是被用户在手动退出的,session会取消所有的后台任务,届时不能再唤醒application,如果想要再次开始传输,必须用户手动开启application。

属性介绍:

@property(readonly, copy) NSString *identifier    

如果在后台任务正在传输时程序退出,可以使用这个identifier在程序重新启动是创建一个新的configuration和session关联之前传输。

@property(copy) NSDictionary *HTTPAdditionalHeaders

默认为空,NSURLRequest附件的请求头。这个属性会给所有使用该configuration的session生成的tasks中的NSURLRequest添加额外的请求头。

重要:不要修改一下请求头
  • Authorization

  • Connection

  • Host

  • WWW-Authenticate

如果这里边添加的请求头跟NSURLRequest中重复了,侧优先使用NSURLRequest中的头。

@property NSURLRequestNetworkServiceType networkServiceType

指定网络传输类型。精切指出传输类型,可以让系统快速响应,提高传输质量,延长电池寿命等。
enum { NSURLNetworkServiceTypeDefault = 0 , 普通网络传输,默认使用这个 NSURLNetworkServiceTypeVoIP = 1 , 网络语音通信传输,只能在VoIP使用 NSURLNetworkServiceTypeVideo = 2 ,影像传输 NSURLNetworkServiceTypeBackground = 3 ,网络后台传输,优先级不高时可使用。对用户不需要的网络操作可使用 NSURLNetworkServiceTypeVoice = 4 语音传输 }; typedef NSUInteger NSURLRequestNetworkServiceType ;

@property BOOL allowsCellularAccess

是否使用蜂窝网络,默认是yes.

@property NSTimeInterval timeoutIntervalForRequest

给request指定每次接收数据超时间隔,如果下一次接受新数据用时超过该值,则发送一个请求超时给该request。默认为60s

@property NSTimeInterval timeoutIntervalForResource

给指定resource设定一个超时时间,resource需要在时间到达之前完成。默认是7天。

@property(copy) NSString *sharedContainerIdentifier

如果要为app的插件提供session,需要给这个值赋值


@property NSHTTPCookieAcceptPolicy HTTPCookieAcceptPolicy

默认值是 NSHTTPCookieAcceptPolicyOnlyFromMainDocumentDomain,如果想更多的cookie控制,可以使用 NSHTTPCookieAcceptPolicyNever,配合 allHeaderFields  跟NSHTTPCookie中方法 cookiesWithResponseHeaderFields:forURL:提取cookie。

typedefenum { NSHTTPCookieAcceptPolicyAlways,NSHTTPCookieAcceptPolicyNever,NSHTTPCookieAcceptPolicyOnlyFromMainDocumentDomain}NSHTTPCookieAcceptPolicy;



@property(retain) NSHTTPCookieStorage *HTTPCookieStorage

存储cookie,清除存储,直接set为nil即可。
对于默认和后台的session,使用 sharedHTTPCookieStorage。
对于短暂的session,cookie仅仅储存到内存,session失效时会自动清除。

@property BOOL HTTPShouldSetCookies

默认为yes,是否提供来自shareCookieStorge的cookie,如果想要自己提供cookie,可以使用 HTTPAdditionalHeaders来提供。


@property(retain) NSURLCredentialStorage *URLCredentialStorage

证书存储,如果不使用,可set为nil.
默认和后台session,默认使用的 sharedCredentialStorage.
短暂的session使用一个私有存储在内存中。session失效会自动清除。

@property(retain) NSURLCache *URLCache

缓存NSURLRequest的response。
默认的configuration,默认值的是 sharedURLCache。
后台的configuration,默认值是nil
短暂的configuration,默认一个私有的cache于内存,session失效,cache自动清除。



@property NSURLRequestCachePolicy requestCachePolicy

缓存策略,默认值是 NSURLRequestUseProtocolCachePolicy 

enum { NSURLRequestUseProtocolCachePolicy = 0 , NSURLRequestReloadIgnoringLocalCacheData = 1 ,不理会cache NSURLRequestReloadIgnoringLocalAndRemoteCacheData = 4 , // Unimplemented NSURLRequestReloadIgnoringCacheData = NSURLRequestReloadIgnoringLocalCacheData , 不理会cache NSURLRequestReturnCacheDataElseLoad = 2 ,返回cache,未命中则拉去远程数据 NSURLRequestReturnCacheDataDontLoad = 3 ,拉去数据,未命中,不做操作 NSURLRequestReloadRevalidatingCacheData = 5 // Unimplemented }; typedef NSUInteger NSURLRequestCachePolicy ;



下图是NSURLRequestUseProtocolCachePolicy的流程图:


image: ../Art/http_caching.pdf

简短说明:
1,如果没有找到对应的request的cache信息,则去请求原始数据。
2,如果cache信息没有指明要重新生成,并且cache没有过期,返回cache response。
3,如果cache过期或者需要重新生成,系统会发送一个HEAD请求去验证cache是否改变。如果改变,拉去原始数据;反之,返回cache response。


@property BOOL sessionSendsLaunchEvents

表示当后台传输结束时,是否启动app.这个属性只对   backgroundSessionConfigurationWithIdentifier:  生效,其他configuration类型会自动忽略该值。默认值是YES。


@property(getter=isDiscretionary) BOOL discretionary

是否由系统根据性能自动裁量后台任务。默认值是NO。同sessionSendsLaunchEvent一样,只对后台configuration有效。

如果传输的是大数据,最好设置成YES。让系统在最佳性能是安排任务。这属性仅当application在前台时会有用。到后台时系统会默认它的值是YES。

@property(copy) NSArray <Class> *protocolClasses

处理NSURLRequest的NSURLProtocol的子类。
重要:对后台Session失效。


@property NSInteger HTTPMaximumConnectionsPerHost

同时连接一个host的最大数。iOS默认是4.APP是作为一个整体来看的。


@property BOOL HTTPShouldUsePipelining

默认值是NO。

@property(copy) NSDictionary *connectionProxyDictionary

默认值是NULL。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值