iOS 集成SDK各种第三方

ios友盟分享初级总结

2016-07-01  本文已影响801人  修中金

友盟分享文档
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(实现新浪微博必须完成的步骤)

1.png 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

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<NSString*,id> *)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

1.png 2.png

1.5 设置分享文本、图片

1.5.1 使用默认UI风格

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

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

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

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





-(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];

}

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

1.png

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

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

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

1.png

2、

增加以下内容:插入到原本内容的</dict>这里</dict>

<key>LSApplicationQueriesSchemes</key><array><string>wechat</string><string>weixin</string><string>sinaweibohd</string><string>sinaweibo</string><string>sinaweibosso</string><string>weibosdk</string><string>weibosdk2.5</string><string>mqqapi</string><string>mqq</string><string>mqqOpensdkSSoLogin</string><string>mqqconnect</string><string>mqqopensdkdataline</string><string>mqqopensdkgrouptribeshare</string><string>mqqopensdkfriend</string><string>mqqopensdkapi</string><string>mqqopensdkapiV2</string><string>mqqopensdkapiV3</string><string>mqzoneopensdk</string><string>wtloginmqq</string><string>wtloginmqq2</string><string>mqqwpa</string><string>mqzone</string><string>mqzonev2</string><string>mqzoneshare</string><string>wtloginqzone</string><string>mqzonewx</string><string>mqzoneopensdkapiV2</string><string>mqzoneopensdkapi19</string><string>mqzoneopensdkapi</string><string>mqqbrowser</string><string>mttbrowser</string><string>alipay</string><string>alipayshare</string><string>renrenios</string><string>renrenapi</string><string>renren</string><string>renreniphone</string><string>laiwangsso</string><string>yixin</string><string>yixinopenapi</string><string>instagram</string><string>whatsapp</string><string>line</string><string>fbapi</string><string>fb-messenger-api</string><string>fbauth2</string><string>fbshareextension</string></array>

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

无标题.png
上一篇下一篇

猜你喜欢

热点阅读