ShareSDK for iOS 适配iOS 9系统
2015-12-22 09:24
701 查看
1、大部分社交平台接口不支持https协议。
问题描述:在iOS9下,系统默认会拦截对http协议接口的访问,因此无法获取http协议接口的数据。对ShareSDK来说,具体表现可能是,无法授权、分享、获取用户信息等。还可能造成我们的编辑界面里传http之类的网络图片的时候,我们的编辑界面不会显示图片截图,解决的办法或者全面关闭https,允许使用http请求;或者把图片的域添加;又或者选择使用https的图片
解决方案(以下方法2选1):
(1)、暂时退回到http协议。
具体方法:
在项目的info.plist中添加一个Key:NSAppTransportSecurity,类型为字典类型。
然后给它添加一个Key:NSAllowsArbitraryLoads,类型为Boolean类型,值为YES;
(2)、设置域。可以简单理解成,把不支持https协议的接口设置成http的接口。
具体方法:
1)、在项目的info.plist中添加一个Key:NSAppTransportSecurity,类型为字典类型。
2)、然后给它添加一个NSExceptionDomains,类型为字典类型;
3)、把需要的支持的域添加給NSExceptionDomains。其中域作为Key,类型为字典类型。
4)、每个域下面需要设置3个属性:NSIncludesSubdomains、NSExceptionRequiresForwardSecrecy、NSExceptionAllowsInsecureHTTPLoads。
均为Boolean类型,值分别为YES、NO、YES。
细节提示:在iOS9中如果使用到网络图片,也要注意网络图片是否是HTTP的哦,如果是,也要把图片的域设置哦!
各平台设置域 | |||
新浪微博 | weibo.com weibo.cn sina.com.cn | ||
腾讯微博 | qq.com | ||
微信 | qq.com | ||
QQ/QZone | qq.com | ||
易信 | 无需配置 | ||
豆瓣 | 无需配置 | ||
人人 | renren.com | ||
开心网 | kaixin001.com kaixin001.com.cn | ||
有道 | youdao.com | ||
Facebook | facebook.com | fbcdn.net | akamaihd.net |
Twitter | twitter.com | ||
Google+ | 无需配置 | ||
Instagram | instagram.com instagramstatic-a.akamaihd.net | ||
Tumblr | tumblr.com | ||
Instapaper | instapaper.com | ||
Pinterest | 无需配置 | ||
明道 | 无需配置 | ||
Evernote印象笔记 | 无需配置 | ||
VK | 无需配置 | ||
pocket | 无需配置 | ||
LinkedIn | 无需配置 | ||
Dropbox | 无需配置 | ||
Flickr Kakao | 无需配置 kakao.com |
2、大部分社交平台SDK不支持bitcode。
问题描述:iOS 9新建项目默认需要支持bitcode,而不支持bitcode的SDK会导致无法编译运行。解决方案:
(1)、暂时关闭对bitcode的支持(建议),方法如下图
(2)、移除不支持bitcode的平台SDK。
3、添加Scheme白名单。
问题描述:在iOS 9下涉及到平台客户端跳转,系统会自动到项目info.plist下检测是否设置平台Scheme。对于需要配置的平台,如果没有配置,就无法正常跳转平台客户端。因此要支持客户端的分享和授权等,需要配置Scheme名单。
具体方法:
1)、在项目的info.plist中添加一LSApplicationQueriesSchemes,类型为Array。2)、然后给它添加一个需要支持的项目,类型为字符串类型;
各平台OpenURL白名单说明 | |
新浪微博 | sinaweibo, sinaweibohd, sinaweibosso, sinaweibohdsso, weibosdk, weibosdk2.5 [后两个若导入新浪SDK则需要] |
腾讯微博 | TencentWeibo, tencentweiboSdkv2 [控制台会提示这两个,但是腾讯微博SDK已经弃用,可以忽略不配置] |
豆瓣 | 无需配置 |
开心网 | 无需配置 |
微信 | wechat, weixin |
易信 | yixin, yixinopenapi |
支付宝 | alipay, alipayshare |
QQ | mqqOpensdkSSoLogin, mqqopensdkapiV2, mqqopensdkapiV3, wtloginmqq2, mqq, mqqapi |
QZONE | mqzoneopensdk, mqzoneopensdkapi, mqzoneopensdkapi19, mqzoneopensdkapiV2, mqqOpensdkSSoLogin, mqqopensdkapiV2, mqqopensdkapiV3, wtloginmqq2, mqqapi, mqqwpa, mqzone, mqq [注:若同时使用QQ和QZONE,则直接添加本格即可] |
Google+ | googlechrome, googlechrome-x-callback, hasgplus4, com.google.gppconsent, com.google.gppconsent.2.2.0, com.google.gppconsent.2.3.0, com.google.gppconsent.2.4.0, com.google.gppconsent.2.4.1 |
人人网 | renrenapi, renrenios, renreniphone, renren, 以及在使用人人SDK时所需配置的URL Scheme,例如:rm226427com.mob.demoShareSDK |
Facebook | fbauth2 |
Twitter | 无需配置 |
Pocket | pocket-oauth-v1 |
Pinterest | pinit |
Instagram | instagram |
WhatsApp | whatsapp |
Line | line |
KakaoTalk | kakaolink |
KaokaoStory | storylink |
LinkedIn | 无需配置 |
Tumblr | 无需配置 |
非平台类,如短信,复制,邮件等 | 无需配置 |
必看注意: | |
1.在iOS9中,如果没有添加上述白名单,系统会打印类似如下提示: .-canOpenURL: failed for URL: “sinaweibohdsso://xxx” – error: “This app is not allowed to query for scheme sinaweibohdsso”(如下图) 如没有添加相关白名单,有可能导致分享失败,例如不会跳转微信,不会跳转QQ等。 | |
2.添加完上述所需的名单,系统依然会打印类似信息: .-canOpenURL: failed for URL: “sinaweibohdsso://xxx” – error: “null” 这是系统打印的信息,目前是无法阻止其打印,即无法消除的 | |
3.上述白名单,是技术人员通过不断的测试收集整理所得,如果各位开发者朋友发现上表格有所遗漏,请根据系统信息添加相关白名单即可。 |
添加完后,系统是依然会打印的,不过error会变成null:
相关文章推荐
- iOS开发之正则表达式的使用-RegexKitLite
- iOS开发之远程推送
- iOS开发-关闭/收起键盘方法总结
- IOS开发之深拷贝与浅拷贝(mutableCopy与Copy)详解-讲得非常棒
- [黑马IOS自学第十六篇]OC分类学习
- [黑马IOS自学第十四篇]Foundation框架学习
- iOS开发之蓝牙通讯
- iOS 支付宝集成
- 低版本XCode支持高版本iOS真机调试的实现
- ios view.frame和view.bounds的区别
- IOS下的 NSTimer与Run loop Modes
- 蜂窝教育iOS培训:掌握iOS技术,才是王道!
- iOS-简单拍照/取照片
- iOS多线程GCD
- IOS 设置多个button,点击切换颜色
- 初探 iOS8 中的 Size Class
- IOS 在iphone中PopoverViewController的使用
- IOS TableViewCell分割线设置和隐藏多余cell
- iOS中文API之NSLayoutconstraint
- 蓝懿iOS 技术内容和心得 12.21