ios友盟分享初级总结

友盟分享文档
http://dev.umeng.com/social/ios/quick-integration#1_3

1.1 下载并安装SDK
安装SDK可以采用CocoaPods和手动下载两种方式,选择下面其中一种来集成即可,以下只说手动集成方式
1.1.2 手动集成SDK
下载最新版的sdk:http://dev.umeng.com/social/ios/sdk-download
解压后拖拽到项目里面
1.2 添加系统需要的framework
• 添加SDK后需要手动添加系统库SystemConfiguration.framework

1.png

· 在other linker flags增加-ObjC 选项,并添加ImageIO 系统framework(实现新浪微博必须完成的步骤)

ios友盟分享初级总结_第1张图片
1.png
ios友盟分享初级总结_第2张图片
1.png

· 添加SDK依赖的系统库文件

在Xcode中打开工程配置文件,选择“summary”一栏。在“summary”中选择“Linked Frameworks and Libraries”一栏,点击“+”图标添加下面八个库文件,分别是

Security.framework

libiconv.dylib

SystemConfiguration.framework

CoreGraphics.Framework

libsqlite3.dylib

CoreTelephony.framework

libstdc++.dylib

libz.dylib

ios友盟分享初级总结_第3张图片
1.png

1.3 设置友盟appkey

· 获取友盟Appkey。如果你之前已经在友盟注册了应用,获得了Appkey,可以继续使用之前获得Appkey。

· 如果你尚未在友盟注册账号,需要先注册,注册之后登录你的账号,点击添加新应用
,完成新应用填写之后,将进入应用管理页面。在该页面就能得到Appkey

· 在代码中设置你的友盟Appkey,在 AppDelegate
文件内设置你的AppKey:

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

 {

    //设置友盟的APPKey

     [UMSocialDatasetAppKey:@"5770f246e0f55a863a000xxx"];

     returnYES;

     }

1.4 配置第三方平台APPID及scheme

1.4.1 配置第三方APPID

这里只列出最常用的微信、QQ及新浪微博的配置方法,其他平台如Facebook等请参考对应文档配置,申请平台APPID请直接参考文档申请第三方账号

在APPdelegate.m文件中增加对应下面的配置

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

//    //设置友盟的APPKey

//   [UMSocialData setAppKey:@"5770f246e0f55a863a000976"];



 //设置微信的AppId,Appkey,和分享URL,需要#import"UMSocialQQHandler.h"

[UMSocialWechatHandlersetWXAppId:@"wx6f2c2f302768cfxx"appSecret:@"309d97f1e1da94fdb3427fad32fc2bxx"url:@"http://www.umeng.com/social"];

//设置手机QQ 的AppId,Appkey,和分享URL,需要#import"UMSocialQQHandler.h"

[UMSocialQQHandler setQQWithAppId:@"11055100xx"appKey:@"Y7ySWBJQU4CnKOxx"url:@"http://www.umeng.com/social"];

//打开新浪微博的SSO开关,设置新浪微博回调地址,这里必须要和你在新浪微博后台设置的回调地址一致。需要#import"UMSocialSinaSSOHandler.h"

[UMSocialSinaSSOHandleropenNewSinaSSOWithAppKey:@"29067283xx"                                             secret:@"340c14750dbe80ff125acecf953309xx"                                       RedirectURL:@"http://sns.whalecloud.com/sina2/callback"];

return YES;

}

1.4.2 配置系统回调

在APPdelegate.m中增加下面的系统回调配置,注意如果同时使用微信支付、支付宝等其他需要改写回调代理的SDK,请在if分支下做区分,否则会影响分享、登录的回调。

//在APPdelegate.m中增加下面的系统回调配置,注意如果同时使用微信支付、支付宝等其他需要改写回调代理的SDK,请在if分支下做区分,否则会影响分享、登录的回调

-(BOOL)application:(UIApplication*)app openURL:(NSURL*)url options:(NSDictionary *)options

{

BOOL rst=[UMSocialSnsServicehandleOpenURL:url];

if (rst==false)

{

    

}

return rst;

}



//添加系统回调 点击返回才不会崩

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

{

BOOL result = [UMSocialSnsServicehandleOpenURL:url];

if (result == FALSE) {

    //调用其他SDK,例如支付宝SDK等

   }

returnresult;

}



-(void)didFinishGetUMSocialDataInViewController:(UMSocialResponseEntity*)response

{

//根据`responseCode`得到发送结果,如果分享成功

if(response.responseCode== UMSResponseCodeSuccess)

{

    //得到分享到的微博平台名

    NSLog(@"share to snsname is %@",[[response.data allKeys] objectAtIndex:0]);

}

}

1.4.3 配置URL scheme

ios友盟分享初级总结_第4张图片
1.png
ios友盟分享初级总结_第5张图片
2.png

1.5 设置分享文本、图片

1.5.1 使用默认UI风格

适用人群:希望10分钟集成从无到有实现分享的开发者

打开需要集成分享功能的视图源码UIViewController.m
,把如下代码复制并粘贴到你将弹出一个分享列表的位置,例如到响应分享按钮的方法中。并且修改下面的友盟appkey,你要分享的文字、图片,你要分享到的微博平台,例如下面写的是新浪微博、QQ、微信。

如在分享按钮点击方法里面写:

首先需要  #import "UMSocial.h"   签协议





-(void)shareAction:(UIButton*)sender

{

//微信、微信朋友圈

[UMSocialData defaultData].extConfig.wechatTimelineData.title= 要分享的标题;

[UMSocialData defaultData].extConfig.wechatSessionData.url= 要分享的url;



//QQ、QQ空间

[UMSocialData defaultData].extConfig.qqData.url=要分享的url;

[UMSocialData defaultData].extConfig.qzoneData.url=要分享的url;

[UMSocialSnsService presentSnsIconSheetView:self

                                     appKey:@"友盟上申请的appkey"

                                  shareText:要分享的url

                                 shareImage:[UIImageimageNamed:要分享的图片]

                            shareToSnsNames:@[UMShareToWechatSession,UMShareToWechatTimeline,UMShareToSina,UMShareToQQ,UMShareToQzone,UMShareToTencent,UMShareToRenren,UMShareToDouban,UMShareToEmail,UMShareToSms]

                                   delegate:self];

}

这时候点击分享按钮就会出现以下界面:

ios友盟分享初级总结_第6张图片
1.png

iOS9.0之后在跳转应用进行授权时,如果没有增加可跳转的白名单,就会提示“您的设备没有安装XXX”,进而只进行webview授权或授权/分享失败,那么如何增加可跳转表名单?

在info.plist中加入可跳转白名单

**1****、****
**
右键info.plist用source code打开:

ios友盟分享初级总结_第7张图片
1.png

2、

增加以下内容:插入到原本内容的这里

LSApplicationQueriesSchemeswechatweixinsinaweibohdsinaweibosinaweibossoweibosdkweibosdk2.5mqqapimqqmqqOpensdkSSoLoginmqqconnectmqqopensdkdatalinemqqopensdkgrouptribesharemqqopensdkfriendmqqopensdkapimqqopensdkapiV2mqqopensdkapiV3mqzoneopensdkwtloginmqqwtloginmqq2mqqwpamqzonemqzonev2mqzonesharewtloginqzonemqzonewxmqzoneopensdkapiV2mqzoneopensdkapi19mqzoneopensdkapimqqbrowsermttbrowseralipayalipaysharerenreniosrenrenapirenrenrenreniphonelaiwangssoyixinyixinopenapiinstagramwhatsapplinefbapifb-messenger-apifbauth2fbshareextension

这时候用 Propert list 方式打开info.plist,即可看到如下如新增的内容

ios友盟分享初级总结_第8张图片
无标题.png

你可能感兴趣的:(ios友盟分享初级总结)