iOS App之间共享数据的方法主要有三种:
Shared User Defaults、Shared Data Container、openURL API。 最近做了一个Today Extension,恰好三种方式都用到了。使用方法逐一记录如下:
Shared User Defaults
1. 创建一个 app group。
选中Host App Target -> Capabilities, 找到 App Groups, 设置为ON。 这时,Xcode会连接developer.apple.com,自动到我的开发者账号中寻找app group,过一会儿就会列出所有曾经创建过的app group。点击加号创建一个新的。命名方式: group.com.weshest.easyword 。 Xcode会自动把新创建的app group添加到开发者账号中。
在Extension中重复以上步骤(不需要创建新的),在列表中选中刚刚创建的就好。
注意:打开了app group之后,Xcode会自动创建一个entitlements文件,在工程的根目录下。在Build Settings -> Code Signing -> Code Signing Entitlements 中,也能看到这个文件名。 因为多了这个entitlements,所以,相应的Provisioning Profile也需要重新生成,生成的步骤和以前相同。
2. 使用app group名称初始化一个NSUserDefaults实例。
let
shared =
NSUserDefaults
(suiteName:
“group.com.weshest.easyword"
)
使用方法和 standardUserDefaults 相同。
Shared Data Container
1. 同样需要创建 app group。 和上面的步骤相同。
2. 使用app group名称初始化一个NSURL实例。
let groupUrl =NSFileManager.defaultManager().containerURLForSecurityApplicationGroupIdentifier(“group.com.wershest.easyword")
let mp3FileUrl = groupUrl?.URLByAppendingPathComponent(“voice.mp3")
使用方法和普通的文件路径相同。
openURL API
1. 在Host App中创建 URL Type。
选中选中Host App Target -> Info, 找到URL Types, 点击加号新建一个。 identifier和URL Schemes可以随意填,最好和bundle id有一定关系,这样比较容易识别。 例如: identifier = com.wershest.easyword ; URL Schemes = easyword-URL
2. 在 AppDelegate 中重载一个函数:
- (BOOL) application: (UIApplication *)application
openURL: (NSURL *)url
sourceApplication: (NSString *)sourceApplication
annotation: (id)annotation {
//在这里可以根据不同的url、url.scheme、url.host执行不同的动作
}
3. 在extension中使用openURL给Host App发送消息。
Application 的openURL是UIApplication的方法。
而在Extension中没有UIApplication,要在
TodayViewController中调用:
if let url =NSURL(string:”easyword-URL://learn") {
self.extensionContext?.openURL(url, completionHandler: { (ret) -> Voidin
})
}