使用ShareSDK完成第三方(QQ、微信、微博)登陆和分享

这几天遇到一个需求:作第三方登陆和分享。遇到了一些坑,把整个过程整理记录下来,方便他人,同时也捋一下思路。css

当时考虑过把每一个平台的SDK下载下来,一个一个弄,一番取舍后决定仍是用ShareSDK。这里只作了微博、微信和QQ。过程以下:c++

1.去ShareSDK官网注册一个帐号方便之后对ShareSDK的配置。sql

2.按照集成文档的步骤开始作,不得不说这个集成文档里面有坑,有坑的地方我会指出。api


文档中心

3.添加一个应用。有不少种方式能够添加一个应用,多点点。这里我建立了一个test应用。服务器


添加应用

建立后进去的页面以下:微信


应用概况

这里的App Key和App Secret(不显示的话,点击显示)很重要,能够用来初始化ShareSDK,app

4.下载SDK。测试


下载SDK

这里是第一个坑,虽然你能够自定义下载SDK,若是你作QQ分享和登陆,必定不要忘记下载QQ空间的SDK。由于QQ自己不支持第三方登陆,但支持第三方分享包括QQ空间分享,QQ空间支持第三方登陆,因此若是你作QQ分享和登陆,必定要记得下载QQ空间的SDK。若是只作分享,那只下载QQ的就行。这里我被坑过,ShareSDK提供的文档里面没有说明。网站


自定义下载SDK

下载后的SDK文件目录:ui


下载后的SDK文件目录

5.把下载的ShareSDK添加到项目中。


项目中的ShareSDK

到如今为止运行项目是会报错的,缘由是没有添加相关的依赖库。

6.添加相关的依赖库。

如下摘自ShareSDK提供的文档。

必须添加的依赖库以下:

SystemConfiguration.framework QuartzCore.framework CoreTelephony.framework libicucore.dylib libz.1.2.5.dylib Security.framework

如下依赖库根据社交平台添加
新浪微博SDK依赖库 (从v2.10.5开始)

ImageIO.framework

QQ好友和QQ空间SSO必要(新注册腾讯开放平台账号只支持SSO受权,只是老开发者才可使用网页受权)

libstdc++.dylib libsqlite3.dylib

添加相应依赖库后的项目结构是这个样子的:


添加相应依赖库后项目结构
到这里运行项目是不会报错的,若是报错,检查添加的依赖库是缺了、漏了、仍是错了。

AppDelegate.m中添加如下头文件,再运行项目看看,这是不会报错的,若是报错看提示信息,多搜索,相信是可以解决的。

#import <ShareSDK/ShareSDK.h> #import <TencentOpenAPI/QQApiInterface.h> #import <TencentOpenAPI/TencentOAuth.h> #import "WXApi.h" #import "WeiboSDK.h"

7.到相应开发者平台注册开发者帐号,并添加你要进行分享和使用第三方登陆应用的信息。

添加新浪微博应用 注册网址 http://open.weibo.com
添加QQ应用 注册网址  http://mobile.qq.com/api/
添加微信应用  http://open.weixin.qq.com

注意:这三家的开放平台,目前为止,页面作的都跟山寨网站似的(微信的好一点),奇卡无比。固然这不是吐槽的重点,重点是注册流程繁琐,还要认证开发者身份,须要等一个工做日。其中若是作微信登陆的话,每一年要交300元的什么费。这里没有什么难度就是个体力活,就不详说了,有什么疑问,请留言,你的留言也是对个人信任和支持。

注册完,申请完就能够拿到AppID、AppSecret、AppKey等东西。


微博的

QQ的

微信的

注:QQ的AppKey在ShareSDK中叫AppSecret。名字不统一,这个比较扯淡。

拿到这些AppID、AppSecret、AppKey等东西后就能够开始对ShareSDK进行初始化。

AppDelegate.m中添加下面这个方法,并记得在- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions方法中调用。

- (void)initShareSDK { [ShareSDK registerApp:@"884a1b86xxxx"]; //对新浪微博SDK进行初始化 [ShareSDK connectSinaWeiboWithAppKey:@"406116xxxx"  appSecret:@"b6a542582057e39a6fca582b14dxxxxxx"  redirectUri:@"http://www.xxxx.com"]; //注这里的redirectUri要与你在新浪微博开放平台上填写的那个受权回调页的URL保持一致,不然在使用微博登陆的时候会报一个redirectUri找不到的错误,这里是一个坑。 //忽然发现这里redirectUri是什么鬼?难道ShareSDK的制做者敲错了?不该该是URL吗? //QQ分享SDK初始化 [ShareSDK connectQQWithQZoneAppKey:@"110467xxxx"  qqApiInterfaceCls:[QQApiInterface class]  tencentOAuthCls:[TencentOAuth class]]; //QQ登陆SDK初始化 [ShareSDK connectQZoneWithAppKey:@"1104677455"  appSecret:@"KnjAB2I0G8Vxxxxx"  qqApiInterfaceCls:[QQApiInterface class]  tencentOAuthCls:[TencentOAuth class]]; // 注:QQ登陆的appSecret参数,是你在QQ开放平台是拿到的AppKey //对微信SDK进行初始化 [ShareSDK connectWeChatWithAppId:@"wx02e84c8fa45xxxx"  appSecret:@"ef9006286ce2637caeb648cb58dxxxx"  wechatCls:[WXApi class]]; }

8.添加URL Schemes。
点击:项目名 > TARGETS > info > URL Types 点击添加URL Types。
如图:


添加URL Schemes

在URL Schemes后面的框里添上对应信息。

新浪微博的URL Schemes是:wb 加上在微博开放平台申请的AppKey。
微信的URL Schemes是:微信开放平台申请的AppID。
QQ空间的URL Schemes是:QQ开放平台申请的 tencent 加上 AppID。(若是只作分享的话,能够不添加,作登陆的话必须添加)
QQ的URL Schemes是:QQ 加上 AppID的16进制(若是AppID转换的16进制数不够8位则在前面补0,如转换的是:5FB8B52,则最终填入为:QQ05FB8B52 注意:转换后的字母要大写)

转换16进制的方法:echo 'ibase=10;obase=16;801312852'|bc,其中801312852为QQ的AppID,见下图:


QQ URLSchemes

添加完URL Schemes后,在AppDelegate.m文件中添加如下对URL处理的代码:

- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url { return [ShareSDK handleOpenURL:url wxDelegate:self]; } - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation { return [ShareSDK handleOpenURL:url sourceApplication:sourceApplication annotation:annotation wxDelegate:self]; }

到此第三方的准备工做就算是作完了。

9.写分享的代码。

(1)在界面上添加按钮,并绑定响应事件。
(2)写事件处理代码。

事件处理代码,以下:

- (void)thridPartyShareWithShareType:(ShareType)shareType { //只须要在响应分享按钮的方法中添加如下代码便可 NSString *img = [[NSBundle mainBundle] pathForResource:@"mm" ofType:@"png"]; //构造分享内容 id<ISSContent> publishContent = [ShareSDK content:@"ShareSDK无比强大哦" defaultContent:@"" image:[ShareSDK imageWithPath:img] title:@"演示Demo中的标题" url:@"http://www.mob.com" description:@"测试DEMO正在制做中,欢迎你们观看" mediaType:SSPublishContentMediaTypeNews]; [ShareSDK shareContent:publishContent type:shareType authOptions:nil shareOptions:nil statusBarTips:YES result:^(ShareType type, SSResponseState state, id<ISSPlatformShareInfo> statusInfo, id<ICMErrorInfo> error, BOOL end) { if (state == SSPublishContentStateSuccess) { NSLog(NSLocalizedString(@"TEXT_SHARE_SUC", @"发表成功")); } else if (state == SSPublishContentStateFail) { NSLog(NSLocalizedString(@"TEXT_SHARE_FAI", @"发布失败!error code == %d, error code == %@"), [error errorCode], [error errorDescription]); } }]; }

方法中的shareType参数传什么值就分享到什么平台:

ShareTypeSinaWeibo            //新浪微博 ShareTypeQQSpace //QQ空间 (注意:填写这个类型就能够分享到好友和QQ空间,也能够用来作登陆) ShareTypeWeixiSession //微信好友 (这个类型也能够用来作微信登陆) ShareTypeWeixiTimeline //微信朋友圈
到这里分享就算是作好了。


10.写登陆代码。(这里在ShareSDK的文档里,又有一个坑)
(1)在ShareSDK作第三方登陆的文档里,这里要求去一个Parse的网站注册下载一大堆东西。并添加一堆依赖库,可这些并无什么卵用。理由以下:

它让在应用了集成Parse,就是作一个对第三方平台返回的信息(id、nickname、profileImage)进行存储,可这些,咱们都是存本身公司服务器的,作这些都是扯淡的,但文档里并无说明。我靠,让我郁闷半天。

(2)在界面添加按钮,并绑定响应事件。
(3)写响应代码(以QQ登陆为例,三个平台的代码是同样的,不一样点在Type这个参数上)。

- (IBAction)QQLogin:(UIButton *)sender { [ShareSDK getUserInfoWithType:ShareTypeQQSpace authOptions:nil result:^(BOOL result, id<ISSPlatformUser> userInfo, id<ICMErrorInfo> error) { if (result) { NSLog(@"%hhd", result); NSLog(@"%@", [userInfo uid]); NSLog(@"%@", [userInfo nickname]); NSLog(@"%@", [userInfo profileImage]); //在这里把拿到的userInfo里面的值作处理,存服务器或者什么的 UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"Hello" message:@"欢迎注册" delegate:nil cancelButtonTitle:@"知道了" otherButtonTitles: nil]; [alertView show]; } else { UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"Hello" message:@"欢迎回来" delegate:nil cancelButtonTitle:@"知道了" otherButtonTitles:nil]; [alertView show]; } }]; }

到这里第三方登陆就算是作好了。
最后,退出登陆受权使用一下代码。

[ShareSDK cancelAuthWithType:ShareTypeQQSpace]; //这里以QQ为例了
相关文章
相关标签/搜索