简单的使用CocoaPods集成ShareSDK

1、首先 cd 至项目的根目录,执行 pod setup;

2、按需在 Podfile 文件中添加命令:


```

#主模块(必须)

pod 'mob_sharesdk'

# UI模块(非必须,需要用到ShareSDK提供的分享菜单栏和分享编辑页面需要以下1行)

pod 'mob_sharesdk/ShareSDKUI'

#平台SDK模块(对照一下平台,需要的加上。如果只需要QQ、微信、新浪微博,只需要以下3行)

pod 'mob_sharesdk/ShareSDKPlatforms/QQ'

pod 'mob_sharesdk/ShareSDKPlatforms/SinaWeibo'

pod 'mob_sharesdk/ShareSDKPlatforms/WeChat'   //(微信sdk不带支付的命令)

# pod 'mob_sharesdk/ShareSDKPlatforms/WeChatFull' //(微信sdk带支付的命令,和上面不带支付的不能共存,只能选择一个)


# ShareSDKPlatforms模块其他平台,按需添加

#如果需要的平台没有对应的平台语句,有2种情况——1、不需要添加这个平台的语句,如Twitter就是这个情况。2、ShareSDK暂时不支持此平台。

pod 'mob_sharesdk/ShareSDKPlatforms/RenRen'

pod 'mob_sharesdk/ShareSDKPlatforms/AliPaySocial'

pod 'mob_sharesdk/ShareSDKPlatforms/Kakao'

pod 'mob_sharesdk/ShareSDKPlatforms/Yixin'

pod 'mob_sharesdk/ShareSDKPlatforms/Facebook'

pod 'mob_sharesdk/ShareSDKPlatforms/Copy'

pod 'mob_sharesdk/ShareSDKPlatforms/Evernote'

pod 'mob_sharesdk/ShareSDKPlatforms/GooglePlus'

pod 'mob_sharesdk/ShareSDKPlatforms/Instagram'

pod 'mob_sharesdk/ShareSDKPlatforms/Instapaper'

pod 'mob_sharesdk/ShareSDKPlatforms/Line'

pod 'mob_sharesdk/ShareSDKPlatforms/Mail'

pod 'mob_sharesdk/ShareSDKPlatforms/SMS'

pod 'mob_sharesdk/ShareSDKPlatforms/WhatsApp'

pod 'mob_sharesdk/ShareSDKPlatforms/MeiPai'

pod 'mob_sharesdk/ShareSDKPlatforms/DingTalk'

pod 'mob_sharesdk/ShareSDKPlatforms/YouTube'

pod 'mob_sharesdk/ShareSDKPlatforms/Twitter'

pod 'mob_sharesdk/ShareSDKPlatforms/Dropbox'

#使用配置文件分享模块(非必需)

pod 'mob_sharesdk/ShareSDKConfigFile'

#扩展模块(在调用可以弹出我们UI分享方法的时候是必需的)

pod 'mob_sharesdk/ShareSDKExtension'

```

如果搜索不到我们这个mob_sharesdk时:

1、请先进行:pod setup

2、再清空一下搜索索引,让pod重建索引:

rm ~/Library/Caches/CocoaPods/search_index.json

注意:之前的命令写法之后会慢慢废弃,建议都使用这个新的命令写法

CocoaPods的介绍和使用,可以参考:网页链接

如果安装过程中遇到问题,可以参考:网页链接

注意:如果pod更新比较慢的话,可以在后面加源,需要集成的命令写法点击此处

三、快速集成

第一步:设置ShareSDK的Appkey并初始化对应的第三方社交平台

在项目工程的Info.plist中如图增加 MOBAppkey 和 MOBAppSecret 两个字段

在MOBAppkey中 设置ShareSDK的appKey,如果尚未在ShareSDK官网注册过App,请移步到登录后台进行应用注册  也可以点击链接看里面的操作步骤。


友情提示:如果您同时多个MOBSDK产品 在info.plist中的设置一次就可以了。

打开*AppDelegate.m(*代表你的工程名字)导入头文件

```

#import

#import

//腾讯开放平台(对应QQ和QQ空间)SDK头文件

#import

#import

//微信SDK头文件

#import“WXApi.h”

//新浪微博SDK头文件<

#import“WeiboSDK.h”

//新浪微博SDK需要在项目Build Settings中的Other Linker Flags添加”-ObjC”

//人人SDK头文件

#import

```

在- (BOOL)application: didFinishLaunchingWithOptions:方法中调用registerApp方法来初始化SDK并且初始化第三方平台(各社交平台申请AppKey的网址及申请流程汇总)

```

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

{

/**初始化ShareSDK应用

@param activePlatforms

使用的分享平台集合

@param importHandler (onImport)

导入回调处理,当某个平台的功能需要依赖原平台提供的SDK支持时,需要在此方法中对原平台SDK进行导入操作

@param configurationHandler (onConfiguration)

配置回调处理,在此方法中根据设置的platformType来填充应用配置信息

*/

[ShareSDK registerActivePlatforms:@[

                            @(SSDKPlatformTypeSinaWeibo),

                            @(SSDKPlatformTypeMail),

                            @(SSDKPlatformTypeSMS),

                            @(SSDKPlatformTypeCopy),

                            @(SSDKPlatformTypeWechat),

                            @(SSDKPlatformTypeQQ),

                            @(SSDKPlatformTypeRenren),

                            @(SSDKPlatformTypeFacebook),

                            @(SSDKPlatformTypeTwitter),

                            @(SSDKPlatformTypeGooglePlus),

]

           onImport:^(SSDKPlatformType platformType)

           {

               switch (platformType)

               {

                  case SSDKPlatformTypeWechat:

                       [ShareSDKConnector connectWeChat:[WXApi class]];

                    break;

                  case SSDKPlatformTypeQQ:

                       [ShareSDKConnector connectQQ:[QQApiInterface class] tencentOAuthClass:[TencentOAuth class]];

                    break;

                  case SSDKPlatformTypeSinaWeibo:

                          [ShareSDKConnector connectWeibo:[WeiboSDK class]];

                    break;

                  case SSDKPlatformTypeRenren:

                          [ShareSDKConnector connectRenren:[RennClient class]];

                    break;

                  default:

                    break;

                }

          }

          onConfiguration:^(SSDKPlatformType platformType, NSMutableDictionary *appInfo)

          {

              switch (platformType)

              {

                  case SSDKPlatformTypeSinaWeibo:

//设置新浪微博应用信息,其中authType设置为使用SSO+Web形式授权

[appInfo SSDKSetupSinaWeiboByAppKey:@”568898243″

appSecret:@”38a4f8204cc784f81f9f0daaf31e02e3″

redirectUri:@”http://www.sharesdk.cn“

                                                 authType:SSDKAuthTypeBoth];

                   break;

                  case SSDKPlatformTypeWechat:

[appInfo SSDKSetupWeChatByAppId:@”wx4868b35061f87885″

appSecret:@”64020361b8ec4c99936c0e3999a9f249″];

                   break;

                  case SSDKPlatformTypeQQ:

[appInfo SSDKSetupQQByAppId:@”100371282″

appKey:@”aed9b0303e3ed1e27bae87c33761161d”

                                         authType:SSDKAuthTypeBoth];

                   break;

                  case SSDKPlatformTypeRenren:

[appInfo        SSDKSetupRenRenByAppId:@”226427″

appKey:@”fc5b8aed373c4c27a05b712acba0f8c3″

secretKey:@”f29df781abdd4f49beca5a2194676ca4″

                                             authType:SSDKAuthTypeBoth];

                    break;

                  case SSDKPlatformTypeFacebook:

[appInfo SSDKSetupFacebookByApiKey:@”107704292745179″

appSecret:@”38053202e1a5fe26c80c753071f0b573″

displayName:@”shareSDK”

                                             authType:SSDKAuthTypeBoth];

                    break;

                  case SSDKPlatformTypeTwitter:

[appInfo SSDKSetupTwitterByConsumerKey:@”LRBM0H75rWrU9gNHvlEAA2aOy”

consumerSecret:@”gbeWsZvA9ELJSdoBzJ5oLKX0TU09UOwrzdGfo9Tg7DjyGuMe8G”

redirectUri:@”http://mob.com”]

                    break;

                   case SSDKPlatformTypeGooglePlus:

[appInfo SSDKSetupGooglePlusByClientID:@”232554794995.apps.googleusercontent.com“

clientSecret:@”PEdFgtrMw97aCvf0joQj7EMk”

redirectUri:@”http://localhost“];

                    break;

                   default:

                    break;

              }

          }];

return YES;

}

(注意:每一个case对应一个break不要忘记填写,不然很可能有不必要的错误,新浪微博的外部库如果不要客户端分享或者不需要加关注微博的功能可以不添加,否则要添加,QQ,微信,google+这些外部库文件必须要加)

```


第二步:添加实现代码打开需要集成分享功能的视图源码,把如下代码复制并粘贴到你要分享的位置,例如到响应分享按钮的方法中。并且修改相应的参数即可。

1.需要在分享的试图中导入的头文件

```

#import

#import

```

2.调用构造分享参数接口和分享的接口

```

//1、创建分享参数

    NSArray* imageArray = @[[UIImage imageNamed:@"shareImg.png"]];

(注意:图片必须要在Xcode左边目录里面,名称必须要传正确,如果要分享网络图片,可以这样传iamge参数 images:@[@"http://mob.com/Assets/images/logo.png?v=20150320"])

    if (imageArray) {


        NSMutableDictionary *shareParams = [NSMutableDictionary dictionary];

[shareParams SSDKSetupShareParamsByText:@"分享内容"

                                         images:imageArray

                                            url:[NSURL URLWithString:@"http://mob.com"]

title:@"分享标题"

                                           type:SSDKContentTypeAuto];

//2、分享(可以弹出我们的分享菜单和编辑界面)

[ShareSDK showShareActionSheet:nil //要显示菜单的视图, iPad版中此参数作为弹出菜单的参照视图,只有传这个才可以弹出我们的分享菜单,可以传分享的按钮对象或者自己创建小的view 对象,iPhone可以传nil不会影响

                                 items:nil

                           shareParams:shareParams

                   onShareStateChanged:^(SSDKResponseState state, SSDKPlatformType platformType, NSDictionary *userData, SSDKContentEntity *contentEntity, NSError *error, BOOL end) {


                       switch (state) {

                           case SSDKResponseStateSuccess:

                           {

UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"分享成功"

                                                                                   message:nil

                                                                                  delegate:nil

cancelButtonTitle:@"确定"

                                                                         otherButtonTitles:nil];

                               [alertView show];

                               break;

                           }

                           case SSDKResponseStateFail:

                           {

UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"分享失败"

                                                                                   message:[NSString stringWithFormat:@"%@",error]

                                                                                  delegate:nil

                                                                         cancelButtonTitle:@"OK"

                                                                         otherButtonTitles:nil, nil];

                                [alert show];

                                break;

                               }

                            default:

                               break;

                       }];


//大家请注意:4.1.2版本开始因为UI重构了下,所以这个弹出分享菜单的接口有点改变,如果集成的是4.1.2以及以后版本,如下调用:

[ShareSDK showShareActionSheet:nil customItems:nil shareParams:shareParams sheetConfiguration:nil onStateChanged:^(SSDKResponseState state, SSDKPlatformType platformType, NSDictionary *userData, SSDKContentEntity *contentEntity, NSError *error, BOOL end) {

        switch (state) {

                           case SSDKResponseStateSuccess:

                           {

UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"分享成功"

                                                                                   message:nil

                                                                                  delegate:nil

cancelButtonTitle:@"确定"

                                                                         otherButtonTitles:nil];

                               [alertView show];

                               break;

                           }

                           case SSDKResponseStateFail:

                           {

UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"分享失败"

                                                                                   message:[NSString stringWithFormat:@"%@",error]

                                                                                  delegate:nil

                                                                         cancelButtonTitle:@"OK"

                                                                         otherButtonTitles:nil, nil];

                                [alert show];

                                break;

                            }

                            default:

                               break;

                            }

}];

```

编译并运行后,点击分享按钮就成功发送到社交平台的话说明你已经基本集成成功了。但是,为了使您的用户有更好的分享体验,以及您的应用有更多的分享量,更好地在社交平台上传播,我们建议您参考“进阶功能”的指引进行SSO(免登录)和更多社交平台的设置。

可选:支持微信所需的相关配置及代码在微信开放平台(http://open.weixin.qq.com/)注册应用并取得应用的AppID,然后打开下图位置,在URL Types中添加微信AppID


打开*AppDelegate.m(*代表你的工程名字)文件,导入微信SDK的头文件并增加微信的外部库接口

```

#import

//微信SDK头文件

#import "WXApi.h"

//初始化的import参数注意要链接原生微信SDK。

case SSDKPlatformTypeWechat:

     [ShareSDKConnector connectWeChat:[WXApi class]];

break;

```

可选:支持QQ所需的相关配置及代码 登录QQ互联(http://connect.qq.com/ )注册成为开发者并登记应用取得AppId,然后打开下图位置,在URL Types中添加QQ的AppID,其格式为:”QQ” + AppId的16进制(如果appId转换的16进制数不够8位则在前面补0,如转换的是:5FB8B52,则最终填入为:QQ05FB8B52 注意:转换后的字母要大写) 转换16进制的方法:echo ‘ibase=10;obase=16;801312852’ |bc,其中801312852为QQ的AppID,见下图



然后打开工程中的*AppDelegate.m(*代表你的工程名字)文件,导入QQSDK的头文件并增加QQ的外部库文件接口:

```

#import

#import

//腾讯开放平台(对应QQ和QQ空间)SDK头文件

#import

#import

//初始化的import参数注意要链接原生QQSDK。

case SSDKPlatformTypeQQ:

      [ShareSDKConnector connectQQ:[QQApiInterface class] tencentOAuthClass:[TencentOAuth class]];

break;

```

可选:配置新浪微博、Facebook的SSO 登录新浪微博和facebook的开放平台,获取AppID 。新浪微博的url scheme的设置格式为wb+Appkey(这个appkey是在微博上注册应用得到的appkey),facebook的设置格式为fb+AppID(这个appid是在facebook上注册应用得到的appkey)。具体参考下图:


附:目前的新浪微博SDK需要在项目的Build Settings中的Other Linker Flags添加”-ObjC”,如果不配置有可能会崩溃。步骤如下:


当新浪微博需要客户端分享或者增加关注微博的功能,需要打开工程中的*AppDelegate.m(*代表你的工程名字)文件,导入新浪微博SDK的头文件并增加新浪微博的外部库文件接口:

```

#import

#import

//新浪微博SDK头文件

#import "WeiboSDK.h"

//初始化的import参数注意要链接原生新浪微博SDK。

case SSDKPlatformTypeSinaWeibo:

      [ShareSDKConnector connectWeibo:[WeiboSDK class]];

break;

```


ZE�k�*�㖐9���

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352

推荐阅读更多精彩内容