1.  U-Share SDK集成

1.1 下载U-Share SDK

通过iOS社会化组件选择所需的社交平台后进行下载,下载链接http://dev.umeng.com/social/ios/sdk-download?spm=0.0.0.0.1up3mE

SDK目录介绍

  1. 1. Document - U-Share SDK文档
  2. 2. UMSocialDemo - U-Share SDK Demo(如点选下载)
  3. 3. UMSocial - U-Share SDK核心目录
  4. UMSocialSDK - U-Share SDK核心framework
  5. UMSocialUI - U-Share 分享UI资源、分享面板framework
  6. SocialLibraries - 所选择下载的第三方平台SDKU-Share链接库
  7.  

1.2  加入U-Share SDK

将U-Share SDK添加到工程

添加项目配置

在Other Linker Flags加入-ObjC

加入依赖系统库

选中项目Target -> Linked Frameworks and Libraries列表中添加依赖库

SystemConfiguration.framework

CoreTelephony.framework

ImageIO.framework

libsqlite3.tbd

libc++.tbd

libz.tbd

2.  U-Share SDK平台配置

从这一步骤就开始需要第三方appKey和appSecret等信息,可参考链接http://dev.umeng.com/social/ios/operation申请所需的平台账号。

2.1  配置各平台URL Scheme

2.1.1  添加URL Types

  • URL Scheme是通过系统找到并跳转对应app的一类设置,通过向项目中的info.plist文件中加入URL types可使用第三方平台所注册的appkey信息向系统注册你的app,当跳转到第三方应用授权或分享后,可直接跳转回你的app。
  • 添加URL Types有如下几处,都可进行设置
  • 通过工程设置面板
  • 通过info.plist文件编辑
  • 直接编辑info.plist中XML代码

2.1.2  配置第三方平台URL Scheme

未列出则不需设置

  格式 举例 备注
微信 微信appKey wxdc1e388c3822c80b  
QQ/Qzone 以下两项都需添加:
1、"tencent"+腾讯QQ互联应用appID 
2、“QQ”+腾讯QQ互联应用appID转换成十六进制(不足8位前面补0)
appID:100424468
1、tencent100424468 
2、QQ05fc5b14
100424468转十六进制为5fc5b14,因不足8位向前补0,结果为05fc5b14,加"QQ"前缀QQ05fc5b14
新浪微博 “wb”+新浪appKey wb3921700954  
钉钉 钉钉appkey dingoalmlnohc0wggfedpk URL Type中的identifier填"dingtalk"
支付宝 “ap”+appID ap2015111700822536 URL Type中的identifier填"alipayShare"
易信 易信appkey yx35664bdff4db42c2b7be1e29390c1a06  
点点虫 点点虫appID 8112117817424282305 URL Type中的identifier填"Laiwang"

2.2  适配iOS9/10系统

iOS9系统后Apple对HTTP请求及访问外部应用做了更加严格的要求,包括HTTP白名单、跳转第三方应用白名单等

2.2.1 HTTPS传输安全

以iOS10 SDK编译的工程会默认以SSL安全协议进行网络传输,即HTTPS,如果依然使用HTTP协议请求网络会报系统异常并中断请求。目前可用如下两种方式保持用HTTP进行网络连接:

在info.plist中加入安全域名白名单(右键info.plist用source code打开)<key>NSAppTransportSecurity</key>

  1. <dict>
  2. <!-- 配置允许 http的任意网络Begin-->
  3. <key>NSAllowsArbitraryLoads</key>
  4. <true/>
  5. <!-- 配置允许 http的任意网络End-->
  6. <key>NSExceptionDomains</key>
  7. <dict>
  8. <!-- U-Share必须配置的HTTP白名单-->
  9. <key>log.umsns.com</key>
  10. <dict>
  11. <key>NSIncludesSubdomains</key>
  12. <true/>
  13. <key>NSTemporaryExceptionAllowsInsecureHTTPLoads</key>
  14. <true/>
  15. <key>NSTemporaryExceptionMinimumTLSVersion</key>
  16. <string>TLSv1.1</string>
  17. </dict>
  18. <key>sns.whalecloud.com</key>
  19. <dict>
  20. <key>NSIncludesSubdomains</key>
  21. <true/>
  22. <key>NSTemporaryExceptionAllowsInsecureHTTPLoads</key>
  23. <true/>
  24. <key>NSTemporaryExceptionMinimumTLSVersion</key>
  25. <string>TLSv1.1</string>
  26. </dict>
  27. <!-- U-Share-->
  28. <!-- 集成微信、QQ、Qzone、腾讯微博授权对应的HTTP白名单-->
  29. <key>qq.com</key>
  30. <dict>
  31. <key>NSIncludesSubdomains</key>
  32. <true/>
  33. <key>NSThirdPartyExceptionAllowsInsecureHTTPLoads</key>
  34. <true/>
  35. <key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
  36. <false/>
  37. </dict>
  38. <!-- 腾讯授权-->
  39. <!-- 集成新浪微博对应的HTTP白名单-->
  40. <key>sina.com.cn</key>
  41. <dict>
  42. <key>NSIncludesSubdomains</key>
  43. <true/>
  44. <key>NSThirdPartyExceptionAllowsInsecureHTTPLoads</key>
  45. <true/>
  46. <key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
  47. <false/>
  48. </dict>
  49. <key>sinaimg.cn</key>
  50. <dict>
  51. <key>NSIncludesSubdomains</key>
  52. <true/>
  53. <key>NSThirdPartyExceptionAllowsInsecureHTTPLoads</key>
  54. <true/>
  55. <key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
  56. <false/>
  57. </dict>
  58. <key>sinajs.cn</key>
  59. <dict>
  60. <key>NSIncludesSubdomains</key>
  61. <true/>
  62. <key>NSThirdPartyExceptionAllowsInsecureHTTPLoads</key>
  63. <true/>
  64. <key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
  65. <false/>
  66. </dict>
  67. <key>sina.cn</key>
  68. <dict>
  69. <!-- 适配iOS10 -->
  70. <key>NSExceptionMinimumTLSVersion</key>
  71. <string>TLSv1.0</string>
  72. <key>NSIncludesSubdomains</key>
  73. <true/>
  74. <key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
  75. <false/>
  76. </dict>
  77. <key>weibo.cn</key>
  78. <dict>
  79. <!-- 适配iOS10 -->
  80. <key>NSExceptionMinimumTLSVersion</key>
  81. <string>TLSv1.0</string>
  82. <key>NSIncludesSubdomains</key>
  83. <true/>
  84. <key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
  85. <false/>
  86. </dict>
  87. <key>weibo.com</key>
  88. <dict>
  89. <!-- 适配iOS10 -->
  90. <key>NSExceptionMinimumTLSVersion</key>
  91. <string>TLSv1.0</string>
  92. <key>NSIncludesSubdomains</key>
  93. <true/>
  94. <key>NSThirdPartyExceptionAllowsInsecureHTTPLoads</key>
  95. <true/>
  96. <key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
  97. <false/>
  98. </dict>
  99. <!-- 新浪微博-->
  100. <!-- 集成人人授权对应的HTTP白名单-->
  101. <key>renren.com</key>
  102. <dict>
  103. <key>NSIncludesSubdomains</key>
  104. <true/>
  105. <key>NSThirdPartyExceptionAllowsInsecureHTTPLoads</key>
  106. <true/>
  107. <key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
  108. <false/>
  109. </dict>
  110. <!-- 人人授权-->
  111. <!-- 集成Facebook授权对应的HTTP白名单-->
  112. <key>facebook.com</key>
  113. <dict>
  114. <key>NSExceptionRequiresForwardSecrecy</key>
  115. <false/>
  116. <key>NSIncludesSubdomains</key>
  117. <true/>
  118. </dict>
  119. <key>fbcdn.net</key>
  120. <dict>
  121. <key>NSExceptionRequiresForwardSecrecy</key>
  122. <false/>
  123. <key>NSIncludesSubdomains</key>
  124. <true/>
  125. </dict>
  126. <key>akamaihd.net</key>
  127. <dict>
  128. <key>NSIncludesSubdomains</key>
  129. <true/>
  130. <key>NSExceptionRequiresForwardSecrecy</key>
  131. <false/>
  132. </dict>
  133. <!-- Facebook授权-->
  134. <!-- 集成Twitter授权对应的HTTP白名单-->
  135. <key>twitter.com</key>
  136. <dict>
  137. <key>NSExceptionRequiresForwardSecrecy</key>
  138. <false/>
  139. <key>NSIncludesSubdomains</key>
  140. <true/>
  141. </dict>
  142. <!-- Twitter授权-->
  143. <!-- 集成Llinkedin授权对应的HTTP白名单-->
  144. <key>linkedin.com</key>
  145. <dict>
  146. <key>NSExceptionAllowsInsecureHTTPLoads</key>
  147. <true/>
  148. <key>NSIncludesSubdomains</key>
  149. <true/>
  150. <key>NSExceptionRequiresForwardSecrecy</key>
  151. <false/>
  152. </dict>
  153. <!-- Llinkedin授权-->
  154. <!-- 集成Kakao授权对应的HTTP白名单-->
  155. <key>kakao.co.kr</key>
  156. <dict>
  157. <key>NSExceptionAllowsInsecureHTTPLoads</key>
  158. <true/>
  159. <key>NSExceptionRequiresForwardSecrecy</key>
  160. <false/>
  161. <key>NSIncludesSubdomains</key>
  162. <true/>
  163. </dict>
  164. <key>kakao.com</key>
  165. <dict>
  166. <key>NSExceptionAllowsInsecureHTTPLoads</key>
  167. <true/>
  168. <key>NSExceptionRequiresForwardSecrecy</key>
  169. <false/>
  170. <key>NSIncludesSubdomains</key>
  171. <true/>
  172. </dict>
  173. <key>kakaocdn.net</key>
  174. <dict>
  175. <key>NSExceptionAllowsInsecureHTTPLoads</key>
  176. <true/>
  177. <key>NSExceptionRequiresForwardSecrecy</key>
  178. <false/>
  179. <key>NSIncludesSubdomains</key>
  180. <true/>
  181. </dict>
  182. <key>kakaocorp.com</key>
  183. <dict>
  184. <key>NSExceptionAllowsInsecureHTTPLoads</key>
  185. <true/>
  186. <key>NSExceptionRequiresForwardSecrecy</key>
  187. <false/>
  188. <key>NSIncludesSubdomains</key>
  189. <true/>
  190. </dict>
  191. <!-- Kakao授权-->
  192. </dict>
  193. </dict>
  194. 2.2.2应用跳转(SSO等)

如果你的应用使用了如SSO授权登录或跳转分享功能,在iOS9/10下就需要增加一个可跳转的白名单,指定对应跳转App的URL Scheme,否则将在第三方平台判断是否跳转时用到的canOpenURL时返回NO,进而只进行webview授权或授权/分享失败。 同样在info.plist增加:

  1. <key>LSApplicationQueriesSchemes</key>
  2. <array>
  3. <!-- 微信 URL Scheme 白名单-->
  4. <string>wechat</string>
  5. <string>weixin</string>
  6. <!-- 新浪微博 URL Scheme 白名单-->
  7. <string>sinaweibohd</string>
  8. <string>sinaweibo</string>
  9. <string>sinaweibosso</string>
  10. <string>weibosdk</string>
  11. <string>weibosdk2.5</string>
  12. <!-- QQ、Qzone URL Scheme 白名单-->
  13. <string>mqqapi</string>
  14. <string>mqq</string>
  15. <string>mqqOpensdkSSoLogin</string>
  16. <string>mqqconnect</string>
  17. <string>mqqopensdkdataline</string>
  18. <string>mqqopensdkgrouptribeshare</string>
  19. <string>mqqopensdkfriend</string>
  20. <string>mqqopensdkapi</string>
  21. <string>mqqopensdkapiV2</string>
  22. <string>mqqopensdkapiV3</string>
  23. <string>mqqopensdkapiV4</string>
  24. <string>mqzoneopensdk</string>
  25. <string>wtloginmqq</string>
  26. <string>wtloginmqq2</string>
  27. <string>mqqwpa</string>
  28. <string>mqzone</string>
  29. <string>mqzonev2</string>
  30. <string>mqzoneshare</string>
  31. <string>wtloginqzone</string>
  32. <string>mqzonewx</string>
  33. <string>mqzoneopensdkapiV2</string>
  34. <string>mqzoneopensdkapi19</string>
  35. <string>mqzoneopensdkapi</string>
  36. <string>mqqbrowser</string>
  37. <string>mttbrowser</string>
  38. <!-- 支付宝 URL Scheme 白名单-->
  39. <string>alipay</string>
  40. <string>alipayshare</string>
  41. <!-- 人人 URL Scheme 白名单-->
  42. <string>renrenios</string>
  43. <string>renrenapi</string>
  44. <string>renren</string>
  45. <string>renreniphone</string>
  46. <!-- 来往 URL Scheme 白名单-->
  47. <string>laiwangsso</string>
  48. <!-- 易信 URL Scheme 白名单-->
  49. <string>yixin</string>
  50. <string>yixinopenapi</string>
  51. <!-- instagram URL Scheme 白名单-->
  52. <string>instagram</string>
  53. <!-- whatsapp URL Scheme 白名单-->
  54. <string>whatsapp</string>
  55. <!-- line URL Scheme 白名单-->
  56. <string>line</string>
  57. <!-- Facebook URL Scheme 白名单-->
  58. <string>fbapi</string>
  59. <string>fb-messenger-api</string>
  60. <string>fbauth2</string>
  61. <string>fbshareextension</string>
  62. <!-- Kakao URL Scheme 白名单-->
  63. <!-- 注:以下第一个参数需替换为自己的kakao appkey-->
  64. <!-- 格式为 kakao + "kakao appkey"-->
  65. <string>kakaofa63a0b2356e923f3edd6512d531f546</string>
  66. <string>kakaokompassauth</string>
  67. <string>storykompassauth</string>
  68. <string>kakaolink</string>
  69. <string>kakaotalk-4.5.0</string>
  70. <string>kakaostory-2.9.0</string>
  71. <!-- pinterest URL Scheme 白名单-->
  72. <string>pinterestsdk.v1</string>
  73. </array>

3.1  初始化设置

3.1.1  初始化U-Share及第三方平台

app启动后进行U-Share和第三方平台的初始化工作 以下代码将所有平台初始化示例放出,开发者根据平台需要选取相应代码,并替换为所属注册的appKey和appSecret。
在AppDelegate.m中设置如下代码

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

[[UMSocialManager defaultManager] openLog:YES];

//设置友盟appkey

[[UMSocialManager defaultManager] setUmSocialAppkey:@"57b432afe0f55a9832001a0a"];

//    NSLog(@"UMeng social version: %@", [UMSocialGlobal umSocialSDKVersion]);

//各平台的详细配置

//设置微信的appId和appKey

[[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_WechatSession appKey:@"wxf84eca1790791ae0" appSecret:@"3baf1193c85774b3fd9d18447d76cab0" redirectURL:@"http://mobile.umeng.com/social"];

//设置分享到QQ互联的appId和appKey

[[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_QQ appKey:@"100424468"  appSecret:@"100424468" redirectURL:@"http://mobile.umeng.com/social"];

//设置新浪的appId和appKey

[[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_Sina appKey:@"3921700954"  appSecret:@"04b48b094faeb16683c32669824ebdad" redirectURL:@"http://sns.whalecloud.com/sina2/callback"];

// 如果不想显示平台下的某些类型,可用以下接口设置

[[UMSocialManager defaultManager] removePlatformProviderWithPlatformTypes:@[@(UMSocialPlatformType_WechatFavorite),@(UMSocialPlatformType_QQ)]];

return YES;

}

3.1.2  设置系统回调

- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation

{

BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];

if (!result) {

}

return result;

}

- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url

{

BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];

if (!result) {

}

return result;

}

3.3  第三方平台分享

3.3.1  弹出分享面板


//点击分享按钮

- (IBAction)share:(id)sender {

     [UMSocialUIManager addCustomPlatformWithoutFilted:UMSocialPlatformType_UserDefine_Begin+2

withPlatformIcon:[UIImage imageNamed:@"二维码图标"]

withPlatformName:@"二维码"];

   [UMSocialShareUIConfig shareInstance].sharePageGroupViewConfig.sharePageGroupViewPostionType =   UMSocialSharePageGroupViewPositionType_Bottom;

   [UMSocialShareUIConfig shareInstance].sharePageScrollViewConfig.shareScrollViewPageItemStyleType =   UMSocialPlatformItemViewBackgroudType_None;

   [UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType   platformType, NSDictionary *userInfo) {

  if (platformType == UMSocialPlatformType_UserDefine_Begin+2) {

    //自定义图标的点击事件

   }

  else{

      [self shareWebPageToPlatformType:platformType];

   }

  }];

}

//网页分享

- (void)shareWebPageToPlatformType:(UMSocialPlatformType)platformType

{

//创建分享消息对象

UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject];

//创建网页内容对象

NSString* thumbURL = IMGAPI(self.imageStr);

NSString *url = [NSString stringWithFormat:SHARE(self.msIdStr)];

UMShareWebpageObject *shareObject = [UMShareWebpageObject shareObjectWithTitle:self.topic descr:url thumImage:thumbURL];

//设置网页地址

shareObject.webpageUrl =url;

//分享消息对象设置分享内容对象

messageObject.shareObject = shareObject;

//调用分享接口

[[UMSocialManager defaultManager] shareToPlatform:platformType messageObject:messageObject currentViewController:self completion:^(id data, NSError *error) {

if (error) {

UMSocialLogInfo(@"************Share fail with error %@*********",error);

}else{

if ([data isKindOfClass:[UMSocialShareResponse class]]) {

UMSocialShareResponse *resp = data;

//分享结果消息

UMSocialLogInfo(@"response message is %@",resp.message);

//第三方原始返回的数据

UMSocialLogInfo(@"response originalResponse data is %@",resp.originalResponse);

}else{

UMSocialLogInfo(@"response data is %@",data);

}

}

//        [self alertWithError:error];

}];

}

其他类型请参考http://dev.umeng.com/social/ios/u-share-api%E6%96%87%E6%A1%A3

介绍就到这里了,至于其他的一些分享大家可以好好看看友盟的官方文档很详细的介绍了如何使用自定义的

这个是链接: http://www.umeng.com/codecenter.html

  1.  
  1.  

iOS快速集成友盟社会化分享功能(v6.1.1)的更多相关文章

  1. Android集成友盟社会化分享功能

    1.  产品概述 友盟社会化组件,可以让移动应用快速具备社会化分享.登录.评论.喜欢等功能,并提供实时.全面的社会化数据统计分析服务. 指南将会手把手教你使用社会化组件SDK,用5分钟为APP增加新浪 ...

  2. React Native中集成友盟社会化分享-----童叟无欺

    1.下载所需的jar,下载地址https://developer.umeng.com/sdk/reactnative?spm=a211g2.211692.0.0.28967d238GW6mC 2.将以 ...

  3. IOS开发之——友盟社会化分享UMSocial_SDK的使用

    友盟第三方官方网址:http://dev.umeng.com/social/ios/quick-integration

  4. cocos2dx集成友盟社会化分享图片崩溃问题

    本人不懂oc,一步一步按照友盟的文档做,好不容易把分享做好了,结果在 分享图片的时候宕掉了.各种测试,搞了一下午终于搞定了. 如下是友盟文档的做法,错误就在[UIImage imageNamed:@& ...

  5. Xamarin.Android 绑定友盟社会化分享组件

    Xamarin.Android 绑定友盟社会化分享组件 最近在开发博客园Android App的时候需要用到友盟社会化分享组件,在github上搜了一下都没有找到最新版本绑定好的项目,就自己动手来绑定 ...

  6. Android Cocos2d-x游戏集成友盟社会化组件分享功能

    最近在帮助开发者集成友盟社会化组件的过程中,发现游戏的集成过程遇到一些困难,而Cocos2d-x具有较好的代表性,因此整理了一篇关于Android Cocos2d-x游戏集成友盟社会化组件指南,由于本 ...

  7. iOS app 集成友盟推送问题

    之前做app推送主要是集成友盟SDK,在程序获取deviceToken时,老是提示如下错误: Error Domain=NSCocoaErrorDomain Code=3000 "未找到应用 ...

  8. iOS友盟社会化分享U-Share分享面板不显示的问题(基本配置没有错误)

    //要先是window可视化 [self.window makeKeyAndVisible]; //添加友盟分享[[UMSocialManager defaultManager] openLog:YE ...

  9. Android集成友盟facebook分享

    在项目中需要将图片和视频分享到社交平台,所以集成了友盟分享.在集成facebook分享的时候走了不少弯路,现在将过程记录下来. 1.先将友盟facebook的jar包复制到项目的libs文件夹下. 2 ...

随机推荐

  1. webpack解惑:多入口文件打包策略

    本文是我用webpack进行项目构建的实践心得,场景是这样的,项目是大型类cms型,技术选型是vue,只支持chrome,有诸多子功能模块,全部打包在一起的话会有好几MB,所以最佳方式是进行多入口打包 ...

  2. 快速Android开发系列网络篇之Android-Async-Http

    先来看一下最基本的用法 AsyncHttpClient client = new AsyncHttpClient(); client.get("http://www.google.com&q ...

  3. ABP源码分析十七:DTO 自动校验的实现

    对传给Application service对象中的方法的DTO参数,ABP都会在方法真正执行前自动完成validation(根据标注到DTO对象中的validate规则). ABP是如何做到的? 思 ...

  4. 【Win10 应用开发】集成文件打开选择器

    有朋友给老周提出建议:老周,能不能在写博客时讲一下有深度的小故事?技术文章谁不会写.讲一下对人生有启发性的故事会更好. 哎呀,这要求真是越来越高了.好吧,尽量吧,如果有小故事的话,老周在就每次写博客时 ...

  5. JavaScript权威设计--JavaScript语言核心(简要学习笔记一)

    1.对象名/值得映射 var book={ top:"a", fat:true }   2.访问对象属性 book.top book["fat"] 3.通过赋值 ...

  6. JVM学习(2)——技术文章里常说的堆,栈,堆栈到底是什么,从os的角度总结

    俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习!涉及到的知识点总结如下: 堆栈是栈 JVM栈和本地方法栈划分 Java中的堆,栈和c/c++中的堆,栈 数据结构层面的堆,栈 os层面 ...

  7. java笔记--笔试中极容易出错的表达式的陷阱

    我相信每一个学过java的人儿们都被java表达式虐过,各种"肯定是它,我不可能错!",然后各种"尼玛,真假,怎么可能?",虽然在实际开发中很少会真的让你去使用 ...

  8. Gatekeeper Pattern 把关(守门人)模式

    Protect applications and services by using a dedicated host instance that acts as a broker between c ...

  9. 【十大经典数据挖掘算法】EM

    [十大经典数据挖掘算法]系列 C4.5 K-Means SVM Apriori EM PageRank AdaBoost kNN Naïve Bayes CART 1. 极大似然 极大似然(Maxim ...

  10. 怎样把win7系统下的屏幕设置成护眼的非常柔和的豆沙绿色?

    经常面对电脑会导致眼睛过度疲劳,白色对眼睛的刺激是最大的,所以,最好不要用白色做电脑背景色 设置方法如下: 在桌面点右键选"个性化",接着点主窗口底部的"窗口颜色&quo ...