标签:
我们知道iOS由于沙盒的存在,应用程序不能越过自己的区域去访问别的存储空间的内容,不过可能有许多场景我们需要在应用程序之间共享数据,比如多个应用共用用户名密码进行登录等。虽然我们不能直接通过文件系统来分享数据,不过还是有些方法可以实现,为了方便说明,这里同时创建了两个工程send和receive,实现这两个app之间的信息共享,send负责写数据,receive负责读数据,具体的demo代码可以到这里获取
剪贴板是应用程序之间传递数据的简单方式,建议不要使用全局的粘贴板,而是自己根据名字创建一个新的粘贴板,防止其它地方全局拷贝的影响。然后把需要共享的内容复制到粘贴板,粘贴板的内容可以是文本、URL、图片和UIColor等,另一个app就可以根据粘贴板的名字去读取相关的信息。
send设置粘贴板的内容:
UIPasteboard *pasteboard = [UIPasteboard pasteboardWithName:@"myPasteboard" create:YES];
pasteboard.string = @"myShareData";
receive读取粘贴板的内容:
UIPasteboard *pasteboard = [UIPasteboard pasteboardWithName:@"myPasteboard" create:NO];
NSString *content = pasteboard.string;
Custom URL Scheme
利用OpenUrl共享数据请看http://www.cnblogs.com/qiaomc/p/5818445.html链接
Shared Keychain Access
iOS的keychain提供一种安全保存信息的方式,可以保存密码等数据,而且keychain中的数据不会因为你删除app而丢失,你可以在重新安装后继续读取keychain中的数据。通常每个应用程序只允许访问自己在keychain中保存的数据,不过假如你使用同一个证书的话,不同的app也可以通过keychain来实现应用间的数据共享
为了实现keychain共享数据,我们需要开启Keychain Sharing,开启方法如下,然后添加设置相同的Keychain Group,不过别忘记了添加Security.framework。
注意:send和receive两个项目都需要开启Keychain Sharing,开启之后会生成xxxxx.entitlements文件,需要在receive项目里的xxxxx.entitlements文件添加send的bundle ID才能正常共享数据
send
receive
send保存数据到keychain(为了简单使用SSKeychian)
[SSKeychain setPassword:@"shareData" forService:@"myservice" account:@"qmc"];
receive读取数据
NSString *myData = [SSKeychain passwordForService:@"myservice" account:@"qmc"];
App Groups
iOS8之后苹果加入了App Groups功能,应用程序之间可以通过同一个group来共享资源,app group可以通过NSUserDefaults进行小量数据的共享,如果需要共享较大的文件可以通过NSFileCoordinator、NSFilePresenter等方式。
开启app groups,需要添加一个group name,app之间通过这个group共享数据:
send项目根据group name设置内容:
NSUserDefaults *myDefaults = [[NSUserDefaults alloc]initWithSuiteName:@"group.cn.goldenshiel.shareData"];
[myDefaults setObject:@"shared data" forKey:@"mykey"];
receive根据group name读取数据
NSUserDefaults *myDefaults = [[NSUserDefaults alloc]initWithSuiteName:@"group.cn.goldenshiel.shareData"];
NSString *content = [myDefaults objectForKey:@"mykey"];
标签:
原文地址:http://www.cnblogs.com/qiaomc/p/5818777.html