APP Extension 与 APP之间的数据共享

APP Extension 是iOS 8以后推出的一个新功能,我们可以通过App Extension快捷的实现一些操作,而不需要再打开APP。在iOS10以后,又新增了iMessageSiri的扩展。iOS12以后,我们还可以通过Intent来实现一些捷径的快捷操作。

image.png

这里主要记录一下APP Extentsion和 主APP之间的数据共享。

虽然APP ExtentsionAPP是在同一个项目当中,但是他们分属不同的Targets, 各自拥有属于自己的沙盒环境。但是在实际操作当中,我们需要在APP Extentsion里面拿到APP的一些数据和资源,这时候就涉及到ExtentsionAPP之间建立起桥接关系了。

下面说下可能会用到的几种情况:

1. 本地数据的共享

由于沙盒限制,通过

    NSUserDefaults *userDefault = [NSUserDefaults standardUserDefaults];

是无法在Extension中获取到APP的数据的。但是Apple提供了一个GroupID,每一个APP可以由于一个唯一的GroupID,通过这个GroupID可以去获取数据。

image.png
NSUserDefaults *userDefaults = [[NSUserDefaults alloc] initWithSuiteName:@"group.xxxxx.IMessageExtension"];
[userDefault setObject:userToken forKey:@"IMessage_User_Token"];

这里需要注意的一点是,这里必须是有效的GroupID,如果是你自己随便定义的key,是无法正常获取到数据的。

2.通过keyChain

我们知道NSUserDefault是把数据存储在Libarary/Preferences目录下,本质上就是一个plist文件。所以有些敏感的数据我们最好不要用这种方式来共享。
Apple还提供了一个安全的数据保存方式,那就是KeyChain。通过KeyChain,我们可以共享一些敏感的数据比如说useridtoken等。

@interface LHKeyChainTool : NSObject

#pragma mark - 存储用户偏好设置到NSUserDefults

+(void)saveUserData:(id)data forKey:(NSString*)key;

#pragma mark读取用户偏好设置

+(id)readUserDataForKey:(NSString*)key;

#pragma mark删除用户偏好设置

+(void)removeUserDataForkey:(NSString*)key;

@end

使用KeyChain的时候需要注意要打开KeychainSharing,并且添加相应的Bundle Id

image.png

3. Pod文件

如果在APP里面使用CocoaPods来管理第三方库,那么在Extension里面是无法直接使用这些文件的,哪怕你可以正常的#import,然后编译器代码提示正常,但是在编译的时候会报找不到头文件的错误。

你可以在项目的podfile文件里面加入这句话:

  link_with '宿主App的名字', '拓展App的名字'

然后执行 pod update --no-repo-update 。如果你是使用了bundle,执行 bundle exec update --no-repo-update

这样就在宿主App和拓展App之间的建立了pod文件的连接。

但是当你只想在Extension当中引用APP的一个或其中几个库时,这样子的全部链接有些不合适,你可以这样做:

target '宿主App的名字' do
        pod ...
        pod ...
        pod ...
end

target '拓展App的名字' do
        pod ...
end

这样子就能在APPExtension之间连接想要的库

4.Assets.xcassets

如果在Extension当中需要用到APP的某些资源图片时,我们不需要再次引用这些资源文件,在xcassets里面直接勾选想要共享的target就可以了

image.png

5.类文件

但是我们并不能通过共享资源的方式来实现类文件的共用。

如果你需要共享的文件不是太多,或者你就是想简单粗暴一点,那就直接把相关的类文件拷贝一份到Extension当中就可以了。

Apple推荐我们通过提取一个公共的framework的方式来优雅的实现数据共享。

image.png

这样子也可以让你的代码更有调理,不会糟糕的互相嵌套import

制作framework的过程这里就不详细展开了。

参考:
App Extension 与 App 之间的数据共享

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269

推荐阅读更多精彩内容