什么是 CloudKit?
CloudKit 提供 API 访问 iCloud 服务器;使用用户的 iCloud 账户来创建一个用户,并且拥有可供每个用户访问的公开权限的数据库,以及每个用户自己的私有数据库来存储信息;也可以通过 CloudKit 的文件存储系统来存储结构化数据和大文件;这一切都不仅仅发生在用户本地,数据被存储在云端,用户可以在任意其它设备上访问。总的来说,CloudKit 是数据库、文件存储、用户认证系统的集合服务。
开启 CloudKit
在 Xcode 的项目设置界面打开 iCloud 开关并勾选 CloudKit 就可以了:
CloudKit 基础对象类型
CloudKit 的基础对象类型有 7 种。
CKContainer: Containers 就像应用运行的沙盒一样,一个应用只能访问自己沙盒中的内容而不能访问其他应用的。Containers 就是最外层容器,每个应用有且仅有一个属于自己的 container。(事实上,经过开发者授权配置 CloudKit Dashboard 之后,一个应用也可以访问其他应用的 container。)
CKDatabase: Database 即数据库,私有数据库用来存储敏感信息,用户只能访问自己的私有数据库。公开的数据库来存储公共信息,公共数据库所有用户都能访问。
CKRecord: 即数据库中的一条数据记录。CloudKit 使用 record 通过 k/v 结构来存储结构化数据。关于键值存储,目前值的架构支持 NSString、NSNumber、NSData、NSDate、CLLocation,和 CKReference、CKAsset,以及存储以上数据类型的数组。
CKRecordZone: Record 不是以零散的方式存在于 database 之中的,它们位于 record zones 里。每个应用都有一个 default record zone,也可以有自定义的 record zone。
CKRecordIdentifier: 是一条 record 的唯一标识,用于确定该 record 在数据库中的唯一位置。
CKReference: Reference 很像 RDBMS 中的引用关系。以地理位置签到应用为例,每个地理位置可以包含很多用户在该位置的签到,那么位置与签到之间就形成了这样一种包含式的从属关系。
CKAsset: 即资源文件,例如二进制文件。还是以签到应用为例,用户签到时可能还包含一张照片,那么这张照片就会以 asset 形式存储起来。
Convenience API
Convenience API 顾名思义是对 CloudKit 操作的便利 API。利用 Convenience API 就可以对 record 进行数据的三种基本操作:存储、读取、更改。
因为 CloudKit 在异步运行saveRecord:completionHandler:时会使用网络与服务器交互,网络状况是不定的,所以一定记得要在 block 中处理错误,一个好的应用应当有完善的错误处理机制。
你需要检查NSError对象来确定正在处理哪种错误。例如,无网络线连接的时候会触发CKErrorNetworkUnavailable类型的错误,然后你需要做的就是失败后重试。
更改已存在记录非常简单,只需要将其获取、更改、保存即可。这里你需要关心的是如何作者三个步骤,特别是当依赖其他 record 来更新一个 record 的时候。
一个更好的解决办法是,使用NSOperation的依赖来管理互相依赖的任务:
有了这些便利的 API,相信你可以做大部分你想做的工作了。这比起写后端代码、租用服务器、部署维护,然后再写客户端代码去和服务端交换信息要简单多了。
查询
远不止如此...
正如我们开始所提到的,CloudKit 能做的还远不止如此。你可以为签到附上图片;对 Checkin 和 Place 之间建立 reference 关联以便能够查询某个地点下的所有签到;甚至,CloudKit 还提供了 API 供你非常方便地查询你通讯录中的好友还有谁也在玩这个应用......
目前苹果允许你使用 CloudKit 存储 10 GB 资源,100 M 数据库存储,每天 2 GB 流量;当你的用户数量增加的时候,这些免费额度也相应地增加到 1 PB 存储、10 TB 数据库存储,以及每天 200 TB 流量。
参见CloudKit cost calculator页面底部来了解详细的免费额度和收费标准。
WWDC 2015 中提到,CloudKit 已经不仅可以在 iOS 和 OS X 上使用,可以在你的网站上集成CloudKit JS,以便 iCloud 用户可以在浏览器中也能使用相应的功能,或者是使用CloudKit web service对 CloudKit 服务端直接进行 HTTP 请求。这意味着,现在其他移动或桌面平台都可以使用 CloudKit 了!