iOS 友盟分享

博文一

1.集成友盟分享,需要先注册一个友盟账号,注册地址

友盟开发者平台官网  友盟集成文档

友盟sdk下载地址友盟sdk下载地址

2,成功下载sdk集成后,微信分享需要配置一下

新浪微博 之类到同样配置就行

3.整合完之后就开始上代码了

ShareManage.h

[objc] view plaincopy

  1. //
  2. //  ShareManage.h
  3. //  KONKA_MARKET
  4. //
  5. //  Created by wxxu on 14/12/18.
  6. //  Copyright (c) 2014年 archon. All rights reserved.
  7. //  分享管理
  8. // 友盟APIKey
  9. #define UMeng_APIKey        @""//友盟appKey
  10. #define WX_APP_KEY @""//微信appId
  11. #define WX_APP_SECRET @""//微信appSecret
  12. #define share_title @""//分享标题
  13. #define share_content @""//分享内容
  14. #define share_url @""//分享url
  15. #import <Foundation/Foundation.h>
  16. #import <MessageUI/MessageUI.h>
  17. @interface ShareManage : NSObject <MFMessageComposeViewControllerDelegate>
  18. + (ShareManage *)shareManage;- (void)shareConfig;/**微信分享**/
  19. - (void)wxShareWithViewControll:(UIViewController *)viewC;/**新浪微博分享**/- (void)wbShareWithViewControll:(UIViewController *)viewC;/**微信朋友圈分享**/- (void)wxpyqShareWithViewControll:(UIViewController *)viewC;/**短信分享**/- (void)smsShareWithViewControll:(UIViewController *)viewC;@end

ShareManage.m

[objc] view plaincopy

  1. //
  2. //  ShareManage.m
  3. //  KONKA_MARKET
  4. //
  5. //  Created by wxxu on 14/12/18.
  6. //  Copyright (c) 2014年 archon. All rights reserved.
  7. //  分享管理
  8. #import "ShareManage.h"
  9. #import "UMSocial.h"
  10. #import "UMSocialWechatHandler.h"
  11. #import "WXApi.h"
  12. @implementation ShareManage {
  13. UIViewController *_viewC;
  14. }
  15. static ShareManage *shareManage;
  16. + (ShareManage *)shareManage
  17. {
  18. @synchronized(self)
  19. {
  20. if (shareManage == nil) {
  21. shareManage = [[self alloc] init];
  22. }
  23. return shareManage;
  24. }
  25. }
  26. #pragma mark 注册友盟分享微信
  27. - (void)shareConfig
  28. {
  29. //设置友盟社会化组件appkey
  30. [UMSocialData setAppKey:UMeng_APIKey];
  31. [UMSocialData openLog:YES];
  32. //注册微信
  33. [WXApi registerApp:WX_APP_KEY];
  34. //设置图文分享
  35. [UMSocialData defaultData].extConfig.wxMessageType = UMSocialWXMessageTypeWeb;
  36. }
  37. #pragma mark 微信分享
  38. - (void)wxShareWithViewControll:(UIViewController *)viewC
  39. {
  40. _viewC = viewC;
  41. [[UMSocialControllerService defaultControllerService] setShareText:share_content shareImage:nil socialUIDelegate:nil];
  42. [UMSocialWechatHandler setWXAppId:WX_APP_KEY appSecret:WX_APP_SECRET url:share_url];
  43. [UMSocialSnsPlatformManager getSocialPlatformWithName:UMShareToWechatSession].snsClickHandler(viewC,[UMSocialControllerService defaultControllerService],YES);
  44. }
  45. #pragma mark 新浪微博分享
  46. - (void)wbShareWithViewControll:(UIViewController *)viewC
  47. {
  48. _viewC = viewC;
  49. [[UMSocialControllerService defaultControllerService] setShareText:share_content shareImage:nil socialUIDelegate:nil];
  50. [UMSocialSnsPlatformManager getSocialPlatformWithName:UMShareToSina].snsClickHandler(viewC,[UMSocialControllerService defaultControllerService],YES);
  51. }
  52. #pragma mark 微信朋友圈分享
  53. - (void)wxpyqShareWithViewControll:(UIViewController *)viewC
  54. {
  55. _viewC = viewC;
  56. [[UMSocialControllerService defaultControllerService] setShareText:share_content shareImage:nil socialUIDelegate:nil];
  57. [UMSocialWechatHandler setWXAppId:WX_APP_KEY appSecret:WX_APP_SECRET url:share_url];
  58. [UMSocialSnsPlatformManager getSocialPlatformWithName:UMShareToWechatTimeline].snsClickHandler(viewC,[UMSocialControllerService defaultControllerService],YES);
  59. }
  60. #pragma mark 短信分享
  61. - (void)smsShareWithViewControll:(UIViewController *)viewC
  62. {
  63. _viewC = viewC;
  64. Class messageClass = (NSClassFromString(@"MFMessageComposeViewController"));
  65. if (messageClass != nil) {
  66. if ([messageClass canSendText]) {
  67. [self displaySMSComposerSheet];
  68. }
  69. else {
  70. //@"设备没有短信功能"
  71. }
  72. }
  73. else {
  74. //@"iOS版本过低,iOS4.0以上才支持程序内发送短信"
  75. }
  76. }
  77. #pragma mark 短信的代理方法
  78. - (void)messageComposeViewController:(MFMessageComposeViewController *)controller didFinishWithResult:(MessageComposeResult)result{
  79. [_viewC dismissViewControllerAnimated:YES completion:nil];
  80. switch (result)
  81. {
  82. case MessageComposeResultCancelled:
  83. break;
  84. case MessageComposeResultSent:
  85. //@"感谢您的分享!"
  86. break;
  87. case MessageComposeResultFailed:
  88. break;
  89. default:
  90. break;
  91. }
  92. }
  93. - (void)displaySMSComposerSheet
  94. {
  95. MFMessageComposeViewController *picker = [[MFMessageComposeViewController alloc] init];
  96. picker.messageComposeDelegate = self;
  97. picker.navigationBar.tintColor = [UIColor blackColor];
  98. //    picker.recipients = [NSArray arrayWithObject:@"10086"];
  99. picker.body = share_content;
  100. [_viewC presentViewController:picker animated:YES completion:nil];
  101. }
  102. @end

[objc] view plaincopy

    博文二

    之前使用过,shareSDK。到了新公司,新公司使用友盟。

    友盟的挺简单的。特分享几个注意点

    0、后来想到的,微博和友盟的绑定

    友盟的使用是很简单,但是,友盟的网站好难用,有木有!!!啥思路

    接着,吐槽。添加了一个新的应用,居然,在我的应用里找不到!但是,在这

    可以找到,不过,第二天,就在我的应用找到了。

    神逻辑呀!

    1、QQ空间的分享。之前老是报错

    [plain] view plaincopyprint?

    1. 2014-09-18 09:52:00.030 友盟快速[239:60b] 分享到QQ空间必须设置图片+文字消息
    2. 2014-09-18:09:52:00:034 -QQAPI- QQApi.m:300 param error:qzone not support type

    在真机上的错误是,无法打开手机QQ。因为,分享到qq好友,可以,所以肯定不是无法打开手机QQ。

    在网上找了许多,都没有直接说明这个问题的。给客服反映,客服木有反应(这点不如,shareSDK)。

    一个半小时,有木有。问题。我早就解决了!

    后来,看到,有个开发者说到,图片和文字为什么不能一起分享,题目和文字怎么分开。我想,是不是我分享的文字的原因,我只是写了“这是要分享的文字”。于是随手添加了N多无聊的文字。可以分享了。

    2、QQ好友分享。只有链接

    这个就是因为,你分享了图片。如果去掉图片,可以看到文字了。

    3、设置QQ各种title

    支持title设置的平台:QQ、QQ空间、微信、微信朋友圈

    [objc] view plaincopyprint?

    1. QQtitle设置方法:
    2. [UMSocialData defaultData].extConfig.qqData.title = @"QQtitle";
    3. QQ空间title设置方法:
    4. [UMSocialData defaultData].extConfig.qzoneData.title = @"Qzonetitle";
    5. 微信title设置方法:
    6. [UMSocialData defaultData].extConfig.wechatSessionData.title = @"微信title";
    7. 朋友圈title设置方法:
    8. [UMSocialData defaultData].extConfig.wechatTimelineData.title = @"朋友圈title";

    4、关于QQ类,无法返回(不包括微信)

    如果,你查看网页,给出的答案是,设置scheme。但是这样还是不行。其实,只要你去友盟的后台绑定一下,QQ空间APPkey绑定就可以类。十六进制那个。

    最后,给大家个绝招。

    如果,你某个功能实现不了。

    使用友盟的账号试试。其实,直接用它的就好。

    我有个功能实现不了,调试了一下午都不行。最后,用都绝招成功。只能说,这个账号不对。

    做这个功能,主要是账号申请费劲,还不一定对,所以,绝招一定要用的!

    时间: 2024-10-06 00:10:42

    iOS 友盟分享的相关文章

    iOS友盟分享--集成Facebook官方SDK

    一直用的友盟分享,最近客户提了个新需求要求可以分享到Facebook  想到友盟就有FB分享 万分激动啊.. 但是测试后发现 友盟的Facebook 两种都存在一定问题.. 第一种   使用系统自带Facebook需要先在手机上设置Facebook账号 优点:这种分享简单 不需要配置Facebook AppID 缺点:继承了系统Facebook 不能预填写分享内容的特点(一般的app分享内容是要预填写的  怎么着也得王婆卖瓜对不对..所以这个缺点很致命); 第二种:使用应用内网页分享 (这种分享

    IOS 友盟分享功能相关问题

    1.分享功能弹出控制面板 [UMSocialSnsService presentSnsIconSheetView:self appKey:@"507fcab25270157b37xxxxxx" shareText:@"你要分享的文字" shareImage:[UIImage imageNamed:@"icon.png"] shareToSnsNames:[NSArray arrayWithObjects:UMShareToSina,UMShare

    iOS开发-友盟分享(3)

    iOS 友盟分享 这个主要是提到如何通过友盟去自定义分享的步骤: 一.肯定要去友盟官网下载最新的SDK包,然后将SDK导入到你的工程文件夹里面去: 二.注册友盟账号,将你的APP添加到你的账号里面然后获取到一个Key; 三.  在AppDelegate内设置友盟AppKey -(BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { [UM

    IOS百度地图使用基础指南+原生分享&友盟分享

    1.地图 1.获取用户的经纬度(CLLocationManager) 创建属性:CLLocationManager *mgr; 遵守协议:<CLLocationManagerDelegate> a>创建定位管理器 self.mgr = [[CLLocationManager alloc] init]; b>设置代理 self.mgr.delegate = self; c>开始定位 [self.mgr startUpdatingLocation]; 代理方法: -(void)l

    iOS之友盟分享

    http://dev.umeng.com/social/ios/share/quick-integration 注意:苹果审核政策需求,建议对未安装的客户端平台进行隐藏,在设置QQ.微信Appid之后调用方法: [UMSocialConfig hiddenNotInstallPlatforms:@[UMShareToQQ, UMShareToQzone, UMShareToWechatSession, UMShareToWechatTimeline]]; 这个接口只对默认分享平面平台有隐藏功能,

    友盟分享到微信的几点备忘(IOS)

    1.下载最新的友盟分享版本,参考友盟官方的demo 2.注册微信开放平台用户,不是公众平台,注册应用 3.参考文档和demo,加入sdk包和相应的lib 4.在plist加入URL types.URL types,可以从demo功能复制过来,同时把相应的参数修改成自己申请的第三方应用的参数,否则不能正常回调 5.在 info-custom ios target properties 加入LSApplicationQueriesSchemes,可以从demo工程复制,否则不能弹出分享窗口 6.在i

    iOS开发——iOS10升级极光推送SDK、友盟分享SDK

    前不久升级了Xcode8 ,同时iOS10系统也推送久. 由于公司需要适配iOS 10系统,同时第三方sdk建议升级. 包含替换升级新的SDK和相应的代码修改. 主要分享如何升级极光推送SDK,友盟分享SDK和升级过程中的遇到的报错 一. 升级极光推送SDK,有一篇不错的博客,代码变更也写的挺详细就不在多写, 遇到的编译报错见第三部分 http://blog.csdn.net/cloud_pro/article/details/52574637 二. 升级友盟分享SDK到目前最新版5.2.1(升

    iOS 友盟第三方登录分享(转载)

    原文地址:http://www.360doc.com/content/15/0121/14/20919452_442560039.shtml // 需要引入框架 // 1. SystemConfiguration.framework // 2. CoreGraphics.framework // 3. libsqlite3.dylib // 4. CoreTelephony.framework // 5. libstdc++.dylib, // 6. libz.dylib // 下载最新的SDK

    IOS友盟 社会化分享 &gt; 社会化iOS组件 &gt; 分享集成

    由于苹果审核政策需求,建议大家对未安装客户端平台进行隐藏,在设置QQ.微信AppID之后调用下面的方法,[UMSocialConfig hiddenNotInstallPlatforms:@[UMShareToQQ, UMShareToQzone, UMShareToWechatSession, UMShareToWechatTimeline]]; 这个接口只对默认分享面板平台有隐藏功能,自定义分享面板或登录按钮需要自己处理 友盟分享sdk5.2.1已经兼容ipv6,请大家升级sdk,避免无法通