IOS项目集成ShareSDK实现第三方登录、分享、关注等功能。

转载 2015年05月12日 15:08:05

(1)官方下载ShareSDK iOS 2.8.8,地址:http://sharesdk.cn/


(2)根据实际情况,引入相关的库,参考官方文档


(3)在项目的AppDelegate中一般情况下有三个操作,第一是注册ShareSDK,第二是注册各个平台的账号,第三是关于微信等应用的回调处理。

  1. //  
  2. //  AppDelegate.m  
  3. //  ShareSDKTest  
  4. //  
  5. //  Created by wangdalei on 14-6-23.  
  6. //  Copyright (c) 2014年 王大雷. All rights reserved.  
  7. //  
  8.   
  9. #import "AppDelegate.h"  
  10. #import "RootViewController.h"  
  11. #import <ShareSDK/ShareSDK.h>  
  12. #import "WeiboApi.h"  
  13. #import <TencentOpenAPI/QQApiInterface.h>  
  14. #import <TencentOpenAPI/TencentOAuth.h>  
  15. #import "WXApi.h"  
  16. #import <TencentOpenAPI/QQApiInterface.h>  
  17. #import <TencentOpenAPI/TencentOAuth.h>  
  18.   
  19. @implementation AppDelegate  
  20. @synthesize rootVC;  
  21.   
  22. - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {  
  23.     self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];  
  24.     if (self.rootVC==nil) {  
  25.         self.rootVC = [[RootViewController alloc]initWithNibName:@"RootViewController" bundle:nil];  
  26.     }  
  27.     UINavigationController *rootNav = [[UINavigationController alloc]initWithRootViewController:self.rootVC];  
  28.     self.window.rootViewController = rootNav;  
  29.     self.window.backgroundColor = [UIColor whiteColor];  
  30.     [self.window makeKeyAndVisible];  
  31.       
  32.       
  33.     <span style="color:#ff0000;">[ShareSDK registerApp:@"1a2e7ab5fb6c"];</span>  
  34.       
  35.    <span style="color:#3366ff;"//添加新浪微博应用 注册网址 http://open.weibo.com  wdl@pmmq.com 此处需要替换成自己应用的  
  36.     [ShareSDK connectSinaWeiboWithAppKey:@"3201194191"  
  37.                                appSecret:@"0334252914651e8f76bad63337b3b78f"  
  38.                              redirectUri:@"http://appgo.cn"];  
  39.       
  40.     //添加腾讯微博应用 注册网址 http://dev.t.qq.com wdl@pmmq.com 此处需要替换成自己应用的  
  41.     [ShareSDK connectTencentWeiboWithAppKey:@"801307650"  
  42.                                   appSecret:@"ae36f4ee3946e1cbb98d6965b0b2ff5c"  
  43.                                 redirectUri:@"http://www.sharesdk.cn"  
  44.                                    wbApiCls:[WeiboApi class]];  
  45.       
  46.     //添加QQ空间应用 注册网址  http://connect.qq.com/intro/login/ wdl@pmmq.com 此处需要替换成自己应用的  
  47.     [ShareSDK connectQZoneWithAppKey:@"100371282"  
  48.                            appSecret:@"aed9b0303e3ed1e27bae87c33761161d"  
  49.                    qqApiInterfaceCls:[QQApiInterface class]  
  50.                      tencentOAuthCls:[TencentOAuth class]];  
  51.       
  52.     //此参数为申请的微信AppID wdl@pmmq.com 此处需要替换成自己应用的  
  53.     [ShareSDK connectWeChatWithAppId:@"wx4868b35061f87885" wechatCls:[WXApi class]];  
  54.       
  55.     //添加QQ应用 该参数填入申请的QQ AppId wdl@pmmq.com 此处需要替换成自己应用的  
  56.     [ShareSDK connectQQWithQZoneAppKey:@"100371282"  
  57.                      qqApiInterfaceCls:[QQApiInterface class]  
  58.                        tencentOAuthCls:[TencentOAuth class]];</span>  
  59.       
  60.     return YES;  
  61. }  
  62.   
  63.   
  64. - (void)applicationWillResignActive:(UIApplication *)application {  
  65.     // Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state.  
  66.     // Use this method to pause ongoing tasks, disable timers, and throttle down OpenGL ES frame rates. Games should use this method to pause the game.  
  67. }  
  68.   
  69. - (void)applicationDidEnterBackground:(UIApplication *)application {  
  70.     // Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later.   
  71.     // If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits.  
  72. }  
  73.   
  74. - (void)applicationWillEnterForeground:(UIApplication *)application {  
  75.     // Called as part of the transition from the background to the inactive state; here you can undo many of the changes made on entering the background.  
  76. }  
  77.   
  78. - (void)applicationDidBecomeActive:(UIApplication *)application {  
  79.     // Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface.  
  80. }  
  81.   
  82. - (void)applicationWillTerminate:(UIApplication *)application {  
  83.     // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:.  
  84. }  
  85.   
  86.   
  87. <span style="color:#ff6600;">#pragma mark - WX回调  
  88.   
  89. - (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url {  
  90.     return [ShareSDK handleOpenURL:url wxDelegate:self];  
  91. }  
  92.   
  93. - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation {  
  94.     return [ShareSDK handleOpenURL:url sourceApplication:sourceApplication annotation:annotation wxDelegate:self];  
  95. }  
  96.   
  97. #pragma mark - WXApiDelegate  
  98.   
  99. /*! @brief 收到一个来自微信的请求,第三方应用程序处理完后调用sendResp向微信发送结果 
  100.  * 
  101.  * 收到一个来自微信的请求,异步处理完成后必须调用sendResp发送处理结果给微信。 
  102.  * 可能收到的请求有GetMessageFromWXReq、ShowMessageFromWXReq等。 
  103.  * @param req 具体请求内容,是自动释放的 
  104.  */  
  105. -(void) onReq:(BaseReq*)req{  
  106.       
  107. }  
  108.   
  109. /*! @brief 发送一个sendReq后,收到微信的回应 
  110.  * 
  111.  * 收到一个来自微信的处理结果。调用一次sendReq后会收到onResp。 
  112.  * 可能收到的处理结果有SendMessageToWXResp、SendAuthResp等。 
  113.  * @param resp具体的回应内容,是自动释放的 
  114.  */  
  115. -(void) onResp:(BaseResp*)resp{  
  116.       
  117. }  
  118. </span>  
  119. @end  


(4)信息分享。

  1. -(IBAction)share:(id)sender{  
  2.     NSString *imagePath = [[NSBundle mainBundle] pathForResource:@"card"  ofType:@"png"];  
  3.     //构造分享内容  
  4.     id<ISSContent> publishContent = [ShareSDK content:@"分享内容测试"  
  5.                                        defaultContent:@"默认分享内容测试,没内容时显示"  
  6.                                                 image:[ShareSDK imageWithPath:imagePath]  
  7.                                                 title:@"pmmq"  
  8.                                                   url:@"http://www.sharesdk.cn"  
  9.                                           description:@"这是一条测试信息"  
  10.                                             mediaType:SSPublishContentMediaTypeNews];  
  11.     [ShareSDK showShareActionSheet:nil  
  12.                          shareList:nil  
  13.                            content:publishContent  
  14.                      statusBarTips:YES  
  15.                        authOptions:nil  
  16.                       shareOptions: nil  
  17.                             result:^(ShareType type, SSResponseState state, id<ISSPlatformShareInfo> statusInfo, id<ICMErrorInfo> error, BOOL end) {  
  18.                                 if (state == SSResponseStateSuccess)  
  19.                                 {  
  20.                                     NSLog(@"分享成功");  
  21.                                 }  
  22.                                 else if (state == SSResponseStateFail)  
  23.                                 {  
  24.                                     NSLog(@"分享失败");  
  25.                                 }  
  26.                             }];  
  27. }  

(5)登录、登出、获取授权信息、关注制定微博

  1. //  
  2. //  LoginViewController.m  
  3. //  ShareSDKTest  
  4. //  
  5. //  Created by wangdalei on 14-6-23.  
  6. //  Copyright (c) 2014年 王大雷. All rights reserved.  
  7. //  
  8.   
  9. #import "LoginViewController.h"  
  10. #import <ShareSDK/ShareSDK.h>  
  11.   
  12. @interface LoginViewController ()  
  13.   
  14. -(IBAction)loginWithSina:(id)sender;  
  15.   
  16. -(IBAction)loginWithQQ:(id)sender;  
  17.   
  18. -(IBAction)loginoutWithSina:(id)sender;  
  19.   
  20. -(IBAction)loginoutWithQQ:(id)sender;  
  21.   
  22. -(IBAction)guanzhuUs:(id)sender;  
  23.   
  24. -(void)reloadStateWithType:(ShareType)type;  
  25.   
  26. @end  
  27.   
  28. @implementation LoginViewController  
  29.   
  30. - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil {  
  31.     self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];  
  32.     if (self) {  
  33.     }  
  34.     return self;  
  35. }  
  36.   
  37. - (void)viewDidLoad {  
  38.     [super viewDidLoad];  
  39. }  
  40.   
  41. - (void)didReceiveMemoryWarning {  
  42.     [super didReceiveMemoryWarning];  
  43. }  
  44.   
  45. - (IBAction)loginWithSina:(id)sender {  
  46.     [ShareSDK getUserInfoWithType:ShareTypeSinaWeibo authOptions:nil result:^(BOOL result, id<ISSPlatformUser> userInfo, id<ICMErrorInfo> error) {  
  47.         NSLog(@"%d",result);  
  48.         if (result) {  
  49.             //成功登录后,判断该用户的ID是否在自己的数据库中。  
  50.             //如果有直接登录,没有就将该用户的ID和相关资料在数据库中创建新用户。  
  51.             [self reloadStateWithType:ShareTypeSinaWeibo];  
  52.         }  
  53.     }];  
  54. }  
  55.   
  56.   
  57. -(IBAction)loginWithQQ:(id)sender{  
  58.     [ShareSDK getUserInfoWithType:ShareTypeQQSpace authOptions:nil result:^(BOOL result, id<ISSPlatformUser> userInfo, id<ICMErrorInfo> error) {  
  59.         NSLog(@"%d",result);  
  60.         if (result) {  
  61.             //成功登录后,判断该用户的ID是否在自己的数据库中。  
  62.             //如果有直接登录,没有就将该用户的ID和相关资料在数据库中创建新用户。  
  63.             [self reloadStateWithType:ShareTypeQQSpace];  
  64.         }  
  65.     }];  
  66. }  
  67.   
  68. -(IBAction)loginoutWithSina:(id)sender{  
  69.     [ShareSDK cancelAuthWithType:ShareTypeSinaWeibo];  
  70.     [self reloadStateWithType:ShareTypeSinaWeibo];  
  71. }  
  72.   
  73. -(IBAction)loginoutWithQQ:(id)sender{  
  74.     [ShareSDK cancelAuthWithType:ShareTypeQQSpace];  
  75.     [self reloadStateWithType:ShareTypeQQSpace];  
  76. }  
  77.   
  78. -(void)reloadStateWithType:(ShareType)type{  
  79.     //现实授权信息,包括授权ID、授权有效期等。  
  80.     //此处可以在用户进入应用的时候直接调用,如授权信息不为空且不过期可帮用户自动实现登录。  
  81.     id<ISSPlatformCredential> credential = [ShareSDK getCredentialWithType:type];  
  82.     UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:NSLocalizedString(@"TEXT_TIPS"@"提示")  
  83.                                                         message:[NSString stringWithFormat:  
  84.                                                                  @"uid = %@\ntoken = %@\nsecret = %@\n expired = %@\nextInfo = %@",  
  85.                                                                  [credential uid],  
  86.                                                                  [credential token],  
  87.                                                                  [credential secret],  
  88.                                                                  [credential expired],  
  89.                                                                  [credential extInfo]]  
  90.                                                        delegate:nil  
  91.                                               cancelButtonTitle:NSLocalizedString(@"TEXT_KNOW"@"知道了")  
  92.                                               otherButtonTitles:nil];  
  93.     [alertView show];  
  94. }  
  95.   
  96. //关注用户  
  97. -(IBAction)guanzhuUs:(id)sender{  
  98.     [ShareSDK followUserWithType:ShareTypeSinaWeibo         //平台类型  
  99.                            field:@"ShareSDK"                //关注用户的名称或ID  
  100.                        fieldType:SSUserFieldTypeName        //字段类型,用于指定第二个参数是名称还是ID  
  101.                      authOptions:nil                        //授权选项  
  102.                     viewDelegate:nil                        //授权视图委托  
  103.                           result:^(SSResponseState state, id<ISSPlatformUser> userInfo, id<ICMErrorInfo> error) {  
  104.                               if (state == SSResponseStateSuccess) {  
  105.                                   NSLog(@"关注成功");  
  106.                               } else if (state == SSResponseStateFail) {  
  107.                                   NSLog(@"%@", [NSString stringWithFormat:@"关注失败:%@", error.errorDescription]);  
  108.                               }  
  109.                           }];  
  110. }  
  111.   
  112.   
  113. @end  

(5)你可能会看到一些应用需要第三方登录的,一种是弹出webView加载的新浪微博或者qq的网页授权,还有一种是跳转到本地的已经安装的新浪微博应用或者qq应用进行授权。第二种授权方式较SSO授权,体验会比较好一些,因为不需要用户输入新浪微博或QQ的用户名与密码。

第二种授权方式需要在plist中配置Scheme。SSO默认是打开的不需要配置。在AppDelegate中实现回调。



(6)测试DEMO截图:







DEMO下载地址:http://download.csdn.net/download/daleiwang/7734321

Android使用ShareSDK集成第三方登录和分享(v3.1.2)

一.产品概述 ShareSDK是一种社会化分享组件,为iOS、Android、WP8 的APP提供社会化功能,集成了一些常用的类库和接口,缩短开发者的开发时间,还有社会化统计分析管理后台。 二...
  • qq_36699930
  • qq_36699930
  • 2018-01-12 11:42:44
  • 511

IOS项目集成ShareSDK实现第三方登录

目前我使用的ShareSDK是简洁版,以下内容摘自ShareSDK简洁版集成文档:官方下载ShareSDK iOS 2.8.8,地址:http://sharesdk.cn/第一步:将下载的SDK解压后...
  • qq_33286156
  • qq_33286156
  • 2016-07-20 17:19:49
  • 947

ShareSDK 分享和第三方登录实现

一、前面部分引用官方文档,按步骤添加ShareSDK到自己的项目中 1. 获取ShareSDK的AppKey          申请ShareSDK的appkey的流程 2....
  • gaobaoshen1
  • gaobaoshen1
  • 2016-06-17 14:37:21
  • 7261

Unity3d使用ShareSDK做分享和第三方登录功能Demo

  • 2016年10月18日 18:31
  • 20.98MB
  • 下载

Android 基于ShareSDK的Facebook第三方登录

ShareSDK中Facebook的登录与其他方式的登录方法一样。 1、在国内开发的话首先当然需要翻墙,翻墙软件很多,可以在网上搜一下,当然付费的较稳定些。 2、登录Facebook开放平台https...
  • Fish20100903
  • Fish20100903
  • 2015-09-07 12:26:58
  • 1514

用shareSdk实现的第三方登录与分享

版权声明:本文为博主原创文章,未经博主允许不得转载。说到第三方登录与分享,其实有很多sdk都支持,不过最常用的还算友盟和mob了,我今天打算记录一下sharesdk的第三方登录与分享,其实也就是简单实...
  • zr940326
  • zr940326
  • 2016-06-21 22:20:43
  • 2294

ShareSDK实现第三方登录和分享

使用ShareSDK实现第三方登录和分享
  • qq_35100122
  • qq_35100122
  • 2016-06-16 15:11:38
  • 7967

IOS项目集成ShareSDK实现第三方登录、分享、关注等功能

ShareSDK官网网址:http://mob.com 快速集成 第一步:将下载的SDK解压后导入您的工程中,见下图(点击这里查看视频教程) 拖到工程中后弹出...
  • huangtianyouhehuangg
  • huangtianyouhehuangg
  • 2015-01-08 14:16:47
  • 1977

ShareSDK集成第三方登录和分享的步骤

转自:http://my.oschina.net/u/1024921/blog/170588 之前用过这个几次了,而每次都没有记录一下具体的步骤,这次就写一下吧 1、去ShareSDK...
  • gf771115
  • gf771115
  • 2014-05-30 13:32:48
  • 100549

Android使用ShareSDK集成QQ、微信、微博等第三方登录

转载请注明出处:http://blog.csdn.net/alpha58/article/details/62424058前言第三方登录几乎是每个APP的必须功能。有些人说看官方的文档实在让人眼花缭乱...
  • Alpha58
  • Alpha58
  • 2017-03-16 15:26:48
  • 4707
收藏助手
不良信息举报
您举报文章:IOS项目集成ShareSDK实现第三方登录、分享、关注等功能。
举报原因:
原因补充:

(最多只允许输入30个字)