(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. #import "AppDelegate.h"
  9. #import "RootViewController.h"
  10. #import <ShareSDK/ShareSDK.h>
  11. #import "WeiboApi.h"
  12. #import <TencentOpenAPI/QQApiInterface.h>
  13. #import <TencentOpenAPI/TencentOAuth.h>
  14. #import "WXApi.h"
  15. #import <TencentOpenAPI/QQApiInterface.h>
  16. #import <TencentOpenAPI/TencentOAuth.h>
  17. @implementation AppDelegate
  18. @synthesize rootVC;
  19. - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
  20. self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
  21. if (self.rootVC==nil) {
  22. self.rootVC = [[RootViewController alloc]initWithNibName:@"RootViewController" bundle:nil];
  23. }
  24. UINavigationController *rootNav = [[UINavigationController alloc]initWithRootViewController:self.rootVC];
  25. self.window.rootViewController = rootNav;
  26. self.window.backgroundColor = [UIColor whiteColor];
  27. [self.window makeKeyAndVisible];
  28. <span style="color:#ff0000;">[ShareSDK registerApp:@"1a2e7ab5fb6c"];</span>
  29. <span style="color:#3366ff;"> //添加新浪微博应用 注册网址 http://open.weibo.com  wdl@pmmq.com 此处需要替换成自己应用的
  30. [ShareSDK connectSinaWeiboWithAppKey:@"3201194191"
  31. appSecret:@"0334252914651e8f76bad63337b3b78f"
  32. redirectUri:@"http://appgo.cn"];
  33. //添加腾讯微博应用 注册网址 http://dev.t.qq.com wdl@pmmq.com 此处需要替换成自己应用的
  34. [ShareSDK connectTencentWeiboWithAppKey:@"801307650"
  35. appSecret:@"ae36f4ee3946e1cbb98d6965b0b2ff5c"
  36. redirectUri:@"http://www.sharesdk.cn"
  37. wbApiCls:[WeiboApi class]];
  38. //添加QQ空间应用 注册网址  http://connect.qq.com/intro/login/ wdl@pmmq.com 此处需要替换成自己应用的
  39. [ShareSDK connectQZoneWithAppKey:@"100371282"
  40. appSecret:@"aed9b0303e3ed1e27bae87c33761161d"
  41. qqApiInterfaceCls:[QQApiInterface class]
  42. tencentOAuthCls:[TencentOAuth class]];
  43. //此参数为申请的微信AppID wdl@pmmq.com 此处需要替换成自己应用的
  44. [ShareSDK connectWeChatWithAppId:@"wx4868b35061f87885" wechatCls:[WXApi class]];
  45. //添加QQ应用 该参数填入申请的QQ AppId wdl@pmmq.com 此处需要替换成自己应用的
  46. [ShareSDK connectQQWithQZoneAppKey:@"100371282"
  47. qqApiInterfaceCls:[QQApiInterface class]
  48. tencentOAuthCls:[TencentOAuth class]];</span>
  49. return YES;
  50. }
  51. - (void)applicationWillResignActive:(UIApplication *)application {
  52. // 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.
  53. // 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.
  54. }
  55. - (void)applicationDidEnterBackground:(UIApplication *)application {
  56. // 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.
  57. // If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits.
  58. }
  59. - (void)applicationWillEnterForeground:(UIApplication *)application {
  60. // 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.
  61. }
  62. - (void)applicationDidBecomeActive:(UIApplication *)application {
  63. // 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.
  64. }
  65. - (void)applicationWillTerminate:(UIApplication *)application {
  66. // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:.
  67. }
  68. <span style="color:#ff6600;">#pragma mark - WX回调
  69. - (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url {
  70. return [ShareSDK handleOpenURL:url wxDelegate:self];
  71. }
  72. - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation {
  73. return [ShareSDK handleOpenURL:url sourceApplication:sourceApplication annotation:annotation wxDelegate:self];
  74. }
  75. #pragma mark - WXApiDelegate
  76. /*! @brief 收到一个来自微信的请求,第三方应用程序处理完后调用sendResp向微信发送结果
  77. *
  78. * 收到一个来自微信的请求,异步处理完成后必须调用sendResp发送处理结果给微信。
  79. * 可能收到的请求有GetMessageFromWXReq、ShowMessageFromWXReq等。
  80. * @param req 具体请求内容,是自动释放的
  81. */
  82. -(void) onReq:(BaseReq*)req{
  83. }
  84. /*! @brief 发送一个sendReq后,收到微信的回应
  85. *
  86. * 收到一个来自微信的处理结果。调用一次sendReq后会收到onResp。
  87. * 可能收到的处理结果有SendMessageToWXResp、SendAuthResp等。
  88. * @param resp具体的回应内容,是自动释放的
  89. */
  90. -(void) onResp:(BaseResp*)resp{
  91. }
  92. </span>
  93. @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. #import "LoginViewController.h"
  9. #import <ShareSDK/ShareSDK.h>
  10. @interface LoginViewController ()
  11. -(IBAction)loginWithSina:(id)sender;
  12. -(IBAction)loginWithQQ:(id)sender;
  13. -(IBAction)loginoutWithSina:(id)sender;
  14. -(IBAction)loginoutWithQQ:(id)sender;
  15. -(IBAction)guanzhuUs:(id)sender;
  16. -(void)reloadStateWithType:(ShareType)type;
  17. @end
  18. @implementation LoginViewController
  19. - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil {
  20. self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
  21. if (self) {
  22. }
  23. return self;
  24. }
  25. - (void)viewDidLoad {
  26. [super viewDidLoad];
  27. }
  28. - (void)didReceiveMemoryWarning {
  29. [super didReceiveMemoryWarning];
  30. }
  31. - (IBAction)loginWithSina:(id)sender {
  32. [ShareSDK getUserInfoWithType:ShareTypeSinaWeibo authOptions:nil result:^(BOOL result, id<ISSPlatformUser> userInfo, id<ICMErrorInfo> error) {
  33. NSLog(@"%d",result);
  34. if (result) {
  35. //成功登录后,判断该用户的ID是否在自己的数据库中。
  36. //如果有直接登录,没有就将该用户的ID和相关资料在数据库中创建新用户。
  37. [self reloadStateWithType:ShareTypeSinaWeibo];
  38. }
  39. }];
  40. }
  41. -(IBAction)loginWithQQ:(id)sender{
  42. [ShareSDK getUserInfoWithType:ShareTypeQQSpace authOptions:nil result:^(BOOL result, id<ISSPlatformUser> userInfo, id<ICMErrorInfo> error) {
  43. NSLog(@"%d",result);
  44. if (result) {
  45. //成功登录后,判断该用户的ID是否在自己的数据库中。
  46. //如果有直接登录,没有就将该用户的ID和相关资料在数据库中创建新用户。
  47. [self reloadStateWithType:ShareTypeQQSpace];
  48. }
  49. }];
  50. }
  51. -(IBAction)loginoutWithSina:(id)sender{
  52. [ShareSDK cancelAuthWithType:ShareTypeSinaWeibo];
  53. [self reloadStateWithType:ShareTypeSinaWeibo];
  54. }
  55. -(IBAction)loginoutWithQQ:(id)sender{
  56. [ShareSDK cancelAuthWithType:ShareTypeQQSpace];
  57. [self reloadStateWithType:ShareTypeQQSpace];
  58. }
  59. -(void)reloadStateWithType:(ShareType)type{
  60. //现实授权信息,包括授权ID、授权有效期等。
  61. //此处可以在用户进入应用的时候直接调用,如授权信息不为空且不过期可帮用户自动实现登录。
  62. id<ISSPlatformCredential> credential = [ShareSDK getCredentialWithType:type];
  63. UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:NSLocalizedString(@"TEXT_TIPS", @"提示")
  64. message:[NSString stringWithFormat:
  65. @"uid = %@\ntoken = %@\nsecret = %@\n expired = %@\nextInfo = %@",
  66. [credential uid],
  67. [credential token],
  68. [credential secret],
  69. [credential expired],
  70. [credential extInfo]]
  71. delegate:nil
  72. cancelButtonTitle:NSLocalizedString(@"TEXT_KNOW", @"知道了")
  73. otherButtonTitles:nil];
  74. [alertView show];
  75. }
  76. //关注用户
  77. -(IBAction)guanzhuUs:(id)sender{
  78. [ShareSDK followUserWithType:ShareTypeSinaWeibo         //平台类型
  79. field:@"ShareSDK"                //关注用户的名称或ID
  80. fieldType:SSUserFieldTypeName        //字段类型,用于指定第二个参数是名称还是ID
  81. authOptions:nil                        //授权选项
  82. viewDelegate:nil                        //授权视图委托
  83. result:^(SSResponseState state, id<ISSPlatformUser> userInfo, id<ICMErrorInfo> error) {
  84. if (state == SSResponseStateSuccess) {
  85. NSLog(@"关注成功");
  86. } else if (state == SSResponseStateFail) {
  87. NSLog(@"%@", [NSString stringWithFormat:@"关注失败:%@", error.errorDescription]);
  88. }
  89. }];
  90. }
  91. @end

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

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

(6)测试DEMO截图:

IOS项目集成ShareSDK实现第三方登录、分享、关注等功能。的更多相关文章

  1. IOS项目集成ShareSDK实现第三方登录、分享、关注等功能(备用)

    (1)官方下载ShareSDK iOS 2.8.8,地址:http://sharesdk.cn/ (2)根据实际情况,引入相关的库,参考官方文档. (3)在项目的AppDelegate中一般情况下有三 ...

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

    (1)官方下载ShareSDK iOS 2.8.8,地址:http://sharesdk.cn/ (2)根据实际情况,引入相关的库,参考官方文档. (3)在项目的AppDelegate中一般情况下有三 ...

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

    原文链接:http://blog.csdn.net/daleiwang/article/details/34081231 (3)在项目的AppDelegate中一般情况下有三个操作,第一是注册Shar ...

  4. iOS开发---集成ShareSDK实现第三方登录、分享、关注等功能。

    (1)官方下载ShareSDK IOS 2.9.6,地址:http://sharesdk.mob.com/Download (2)根据实际情况,引入相关的库,参考官方文档. (3)在项目的AppDel ...

  5. iOS:友盟SDK第三方登录 分享及友盟统计的使用

    本文转载至 http://www.it165.net/pro/html/201503/37101.html Tag标签:第三方   01.#import "UMSocial.h" ...

  6. iOS项目中常用的第三方开源库

    1.项目使用的第三方开源库 项目使用了CocoaPods(类似java中的maven)管理常用的第三方库,一些特殊的单独引用,下面介绍下比较好用的几个. (1)AFNetworking 目前比较推荐的 ...

  7. 现有iOS项目集成React Native过程记录

    在<Mac系统下React Native环境搭建>配置了RN的开发环境,然后,本文记录在现有iOS项目集成React Native的过程,官方推荐使用Cocoapods,项目一开始也是使用 ...

  8. php+redis实现注册、删除、编辑、分页、登录、关注等功能

    本文实例讲述了php+redis实现注册.删除.编辑.分页.登录.关注等功能.分享给大家供大家参考,具体如下: 主要界面 ​ 连接redis redis.php <?php //实例化 $red ...

  9. 利用ShareSDK进行第三方登录和分享

    到相应开发者平台注册开发者账号,并添加你要进行分享和使用第三方登录应用的信息. 添加新浪微博应用 注册网址 http://open.weibo.com添加QQ应用 注册网址  http://mobil ...

随机推荐

  1. Lua中的协同程序 coroutine

    Lua中的协程和多线程很相似,每一个协程有自己的堆栈,自己的局部变量,可以通过yield-resume实现在协程间的切换.不同之处是:Lua协程是非抢占式的多线程,必须手动在不同的协程间切换,且同一时 ...

  2. java trim

    rim方法一般用来去除空格,但是根据JDK API的说明,该方法并不仅仅是去除空格,它能够去除从编码’\u0000′ 至 ‘\u0020′ 的所有字符. 回车换行也在这20个字符之中,以下是一个示例: ...

  3. ionic 添加地图定位功能

    由于项目需求,需要一个定位功能,通过google或百度,搜到一个cordova-plugin-geolocation的插件,在ios上可以用,但是在android就呵呵了,原因就不说了,大家都知道.所 ...

  4. bootstrap插件学习-bootstrap.tooltip.js

    先看bootstrap-tooltip.js的结构 var Tooltip = function ( element, options ){} // 构造器 Tooltip.prototype ={} ...

  5. 100行JS实现HTML5的3D贪吃蛇游戏

    js1k.com收集了小于1k的javascript小例子,里面有很多很炫很酷的游戏和特效,今年规则又增加了新花样,传统的classic类型基础上又增加了WebGL类型,以及允许增加到2K的++类型, ...

  6. MVC知识点02

    MVC基础知识详情 1:在MVC中如果要从前台页面(.aspx)获取参数,只需要将其两个页面的参数设置成一样的,这样子MVC中的机制就会自动的将参数的值传到方法中. 2:在MVC中的方法要是两个都是相 ...

  7. 做java工作整整1年了,看到了大牛的奋斗历程,我感觉自己又有目标了

    2014年6月,刚刚踏上社会那会儿,我记得我第一次面试啥都不知道,穿的也不修边幅去应聘一家4s销售,面试官看到我,我明细感觉到了对方厌恶的神色,这是我上社会的第一课,找工作不管是什么工作,衣着得体,是 ...

  8. Hibernate框架之注解的配置

    在hibernate中,通常配置对象关系映射关系有两种,一种是基于xml的方式,另一种是基于annotation的注解方式,熟话说,萝卜青菜,可有所爱,每个人都有自己喜欢的配置方式,我在试了这两种方式 ...

  9. Android 手机卫士11--窗体弹出PopupWindow

    protected void showPopupWindow(View view) { View popupView = View.inflate(this, R.layout.popupwindow ...

  10. ThoughtWorks.QRCode生成二维码

    首先引用需要的dll,此处使用的是ThoughtWorks.QRCode.dll,网上可以找到对应的,此处也有一份,点击下载 http://files.cnblogs.com/files/ives/T ...