简述
URL加载系统是让你的app通过相应的URL加载对应内容的类-classes
和协议-protocols
的集合。其中,核心的技术是NSURL
类,NSURL
类能够让你的app操纵你的URLs
和它所对应的资源。为了支持URL
类,Foundation
框架提供了丰富的类让你去加载一个URL
、上传数据、管理cookie
存储、控制response
缓存、处理证书存储和授权以及自定义协议扩展。
URL
加载系统支持以下协议获取资源
- 文件传输协议:
ftp://
- 超文本传输协议:
http://
- 安全套接字层超文本传输协议:
https://
- 本地文本传输协议:
file:///
- Data URLs
data://
很明显,URL
加载系统也可以通过使用用户的系统偏好设置支持代理服务器和SOCKS
网关。
重要指出:在苹果平台上,被称作“App Transport Security (ATS)”的网络安全特性在默认情况下同样适用于app和app extensions。它通过使用行业标准协议和无已知弱点计算方式提高了隐私和数据的安全性。
提示:除了URL
加载系统,OS X和iOS还提供了一些开启其他应用程序URLs
的APIs,比如说Safari
,这些APIs在本文档不做详述
一览表
URL
加载系统包括加载URLs
的类以及许多和这些类一起起作用的一些重要的辅助类,它们共同去修改系统行为。主要的辅助类分为以下五类,分别是:协议支持、授权和证书、cookie
存储、配置管理以及缓存管理。
URL
加载
在URL
加载系统中,最常用的是从一个URL
所对应的地址获取资源。你可以用NSURLSession
获取内容。而所使用的方法主要依赖于你是想把数据缓存还是想把数据储到硬盘上。
以Data
方式获取数据(缓存)
在较高层面(非底层)而言,下载一个URL
所对应的文件内容有两种基本方式
- 1 对于简单的请求,利用
NSURLSession
直接从一个NSURL
请求内容,或者从本地硬盘上获取对应的NSData
或者文件(file) (这里相当于请求本地数据) - 2 对于复杂的上传数据请求,例如,我们可以为
NSURLSession
提供NSURLRequest
对象(或者它的子类NSMutableURLRequest
)
无论你选择哪种方式,你的app获取返回数据的方式只有两种:
- 1 提供一个完成处理的
block
,当从服务器获取数据后,URL
加载类去调用这个block
- 2 提供一个自定义代理方法,当从服务器接受到元数据后,
URL
加载类会周期性的调用这个代理方法。如果需要,你的app可以拼接返回的数据
相关章节:使用NSURLSession
除了数据本身外,URL
加载类还为代理或者block
提供了包装了元数据的请求返回值,比如MIME type
和content length
以文件file
的形式下载内容
在高层面上,有两个基本方法可以下载一个URL对应的内容。
- 1 对于简单的请求,用
NSURLSession
API直接从一个NSURL对象请求内容,或者从本地硬盘上获取对应的NSData或者文件(file) - 2 对于更加复杂的请求,如上传请求,可以为
NSURLSession
提供NSURLRequest
对象(或者它的子类NSMutableURLRequest
)
提示:通过
NSURLSession
实例对象初始化的下载不会进行缓存。如果你需要对结果进行缓存,你的app需要使用NSURLSession
写数据到磁盘上。
相关章节:使用NSURLSession
辅助类(Helper Classes
)
URL
加载类用了两个提供元数据的辅助类,一个是用于请求自身的(NSURLRequest
),一个是用于服务器相应的(NSURLResponse
)
1.URL
请求(URL Requests
)
一个NSURLRequest
对象以独立于协议的方式包装了一个URL
和协议指定的所有属性(properties
)。
提示:当客户端app使用
NSMutableURLRequest
初始化一个连接或下载时,就会产生一个请求(request
)的深拷贝。在下载对象初始化后,再改变这个request
对于下载操作不会产生影响。
一些协议支持协议指定属性,例如,HTTP
协议将方法添加到NSURLRequest
上,返回HTTP
的请求体,请求头和传输方法。它也可以添加到NSMutableURLRequest
上设置那些值。关于使用URL
对象的细节介绍都在本书阐述了。
2. 响应元数据(Response Metadata
)
服务器的响应可视为两部分:元数据描述的内容和数据本身的内容。对于大多数协议,元数据都是由NSURLResponse
类包装(或封装)的。包含MIME
类型,预期的content length
,text encoding
以及响应的URL
。指定协议的NSURLResponse
的子类可以提供额外的元数据。例如 NSHTTPURLResponse可以储存web
服务器返回的请求头和状态码。
重要信息:只有响应的元数据存储在
NSURLResponse
对象中。各种URL
加载类提供自身的响应数据给你的app,要么通过block
回调,要么通过代理。一个NSCachedURLResponse
实例封装了一个NSURLResponse
对象、URL
内容数据(URL content data)以及一些你的app提供的额外信息。更详细的,可以看下面的缓存管理
重定向和其他的请求改变(Redirection and Other Request Changes
)
一些协议(例如HTTP
)为服务器提供了一种告诉您的应用程序内容已转移到其他URL的方法。 URL
加载类可以在发生这种情况时通知他们的代理。 如果您的应用程序提供了适当的委托方法,您的应用程序可以决定是否遵循重定向,从重定向返回响应正文,或返回错误。
相关章节:处理重定向以及其他的请求变化
认证和证书(Authentication and Credentials
)
一些服务器对某些内容的获取是有限制的,它需要用户提供一些认证信息——一个客户端证书、用户的姓名、密码等等进行认证。就web
服务器而言,限制内容被分成一块一块,每一块都需要单独的一套认证信息(credentials
)。认证信息,尤其是证书也是用来确定是否可以信任另一方的——去评估你的app是否可以信任服务器。
URL
加载系统提供了一些类,包括model credentials
,保护区域(protected areas
)和安全证书持久化(secure credential persistence
)。您的应用可以指定这些证书(凭据)在应用启动期间持续存在,也可以永久保存在用户的钥匙串中。
提示:以持久化的方式存储认证信息,认证信息会存储在用户的钥匙链中(
keychain
),并且所有的app可以共享。
NSURLCredential类封装了一个包含用户认证信息(例如,用户姓名和密码)和持久性行为的证书。NSURLProtectionSpace类表示需要特定凭据的区域,一个保护空间可以限制在一个URL
上,一个保护空间包含一个web
服务器上的区域或指一个代理服务器(A protection space can be limited to a single URL, encompass a realm on a web server, or refer to a proxy
)。一个NSURLCredentialStorage对象管理一个会话的证书(credential
)存储并且提供'NSURLCredential'对象到其提供身份验证的相应'NSURLProtectionSpace'对象的映射。只有验证挑战(authentication challenge
)成功,才会存储证书。NSURLAuthenticationChallenge类封装了一个认证请求的NSURLProtocol实现所需要的信息:一个建议的凭证,涉及的保护空间,用协议确定需要验证的错误或响应以及尝试认证的次数。NSURLAuthenticationChallenge
实例还指定了开启认证的的对象。初始化对象,也称为发送者,必须符合NSURLAuthenticationChallengeSender协议。NSURLProtocol
的子类需要用NSURLAuthenticationChallenge
实例告知URL
加载系统需要身份认证。他们也为NSURLSession代理方法提供了自定义认证处理。
相关章节:身份验证挑战和
TLS
链的认证(Authentication Challenges and TLS Chain Validation)
缓存管理(Cache Management
)
URL加载系统提供了一个复合的磁盘和内存缓存,减少了应用程序对网络连接的依赖性,并为先前缓存的响应提供更快的往返时间。缓存基于每个应用程序存储。根据由NSURLRequest和NSURLSessionConfiguration对象指定的缓存策略,NSURLSession查询缓存。NSURLCache类提供了配置缓存大小及其在磁盘上的位置的方法。它还提供了管理包含缓存响应的NSCachedURLResponse对象的集合的方法。NSCachedURLResponse
对象封装了NSURLResponse对象和URL
内容数据。NSCachedURLResponse
还提供了一个用户信息字典(dictionary
),您的应用程序可用于缓存任何自定义数据。并非所有协议实现都支持响应缓存。 目前只有http
和https
请求可以缓存。NSURLSession对象可以通过实现URLSession:dataTask:willCacheResponse:completionHandler:delegate方法来控制是否缓存响应以及响应是否应仅缓存在内存中。
Cookie存储
由于HTTP
协议的无状态性,客户端经常使用cookie来提供跨URL
请求的数据的持久存储。URL
加载系统提供了创建和管理Cookie
的接口,作为HTTP
请求的一部分发送cookies
,并在解译Web服务器响应时接收cookie
。OS X
和iOS
提供了NSHTTPCookieStorage类,它们又提供用于管理NSHTTPCookie对象集合的接口。 在OS X
中,Cookie
存储在所有应用程序之间共享; 在iOS中,Cookie只存储是每个应用程序中。
相关章节:
Cookie
存储
协议支持
URL加载系统本身支持http
,https
,file
,ftp
和数据协议。 然而,URL
加载系统还允许您的应用程序注册自己的类以支持其他应用层网络协议。 您还可以向URL
请求和URL
响应对象添加特定于协议的属性。
相关章节:Cookies 和自定义协议
如何使用文档
首先通过阅读使用NSURLSession了解URL
加载系统的概述。 然后阅读URL
会话的生命周期,详细了解NSURLSession
如何与其代理进行交互。 有关URL加载系统的其他方面的更多信息,请参见以下章节:
- 编码URL数据解释了如何编码任意字符串,使其安全地用于URL
- 处理重定向和其他请求更改描述了您对URL请求的更改进行响应的选项。
- 身份验证挑战和TLS链验证描述了对安全服务器进行身份验证的过程。
- 理解缓存访问描述了在请求期间连接如何使用缓存。
-
Cookies
和定制协议解释了可用于管理Cookie
存储和支持自定义应用层协议的类。