基于第三方QQ授权登录和新浪微博授权登录的iOS代码分析

基于iOS实现APP的第三方登陆之QQ和新浪微博授权,在开发中明显能感觉到两家SDK的差异和易用性,这里先赘述下接入第三方SDK时的一个基本的步骤:

1,确定用需中需要这样一个功能,如果QQ登录,似乎主流了,APP注册标配啊;

2,找到相关的开放平台,如QQ互联平台,http://connect.qq.com/;

3,注册成功后创建自己的APP,填写一堆基本信号后获得一个App_Key,就是你APP的唯一识别码;

4,下载对应的SDK,并且阅读其中的开发文档或demo,通常看开发文档比较直观,如果看demo,有些SDK的demo简直不忍直视;

5,嵌入SDK中对应功能,测试成功后提交第三方平台审核,等审核通过后就可以正式接入第三方SDK的功能了;

6,完成所有功能后就提交AppStore审核吧,大概一周左右即可。


呃,说了这么多,让我们来进入QQ登录和新浪微博登录授权具体操作,这种简便的登录方式大大简化了用户的注册之苦,同时也扩展了APP的社交性,更易于分享和推广,在登录后都可以获得用户的唯一ID,只有APP后台绑定这个ID,就等于用户注册了该APP一样,似乎变成了各大APP的标配登录模式,吐槽,似乎抽屉式设计慢慢的又变回TabBar式了,具体原因可参考网络资源。


一,QQ登录授权开发:

1,按照开发文档导入SDK,然后把注册成功后获取到的Key加入到Url Schemes中,例如:tencent1101737816,注意这些文档写的很清楚;

2,在AppDelegate.m中实现下面方法,注意,直接复制代码,两者写其一即可,当然了别忘了引入头文件,这是用作返回APP时候用的回调函数

[objc]  view plain copy print ?
  1. <span style="font-size:14px;"><span style="font-size:14px;">- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation  
  2. {  
  3.     return [TencentOAuth HandleOpenURL:url];  
  4. }  
  5.   
  6. - (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url  
  7. {  
  8.     return [TencentOAuth HandleOpenURL:url];  
  9. }  
  10. </span></span>  
3,注册并授权,注意授权这里会出现问题

_tencentOAuth = [[TencentOAuth alloc] initWithAppId:kQQ_KEY andDelegate:self];   //注册

[objc]  view plain copy print ?
  1. <span style="font-size:14px;"NSArray *_permissions = [NSArray arrayWithObjects:kOPEN_PERMISSION_GET_INFO, kOPEN_PERMISSION_GET_USER_INFO, kOPEN_PERMISSION_GET_SIMPLE_USER_INFO, nil nil];  
  2.     [_tencentOAuth authorize:_permissions inSafari:NO]; //授权</span>  

注意:在官方文档中提到授权代码是: _permissions = [[NSArray arrayWithObjects:@"get_user_info", @"add_t", nil] retain]; //官方授权代码

如果你写成这样,你会发现始终登录不了,提示权限不够,非常坑爹,正确授权代码如上面的写法,切记

4,实现登录成功与否的回调函数,实现协议TencentSessionDelegate,代码如下:

[objc]  view plain copy print ?
  1. <span style="font-size:14px;"><span style="font-size:18px;">- (void)tencentDidLogin  
  2. {  
  3.     _labelTitle.text = @"登录完成";  
  4.       
  5.     if (_tencentOAuth.accessToken && 0 != [_tencentOAuth.accessToken length]){  
  6.         //  记录登录用户的OpenID、Token以及过期时间  
  7.         _labelAccessToken.text = _tencentOAuth.accessToken;  
  8.           
  9.     }else{  
  10.         _labelAccessToken.text = @"登录不成功 没有获取accesstoken";  
  11.     }  
  12. }  
  13.   
  14. -(void)tencentDidNotLogin:(BOOL)cancelled  
  15. {  
  16.     if (cancelled){  
  17.         _labelTitle.text = @"用户取消登录";  
  18.     }else{  
  19.         _labelTitle.text = @"登录失败";  
  20.     }  
  21. }  
  22.   
  23. -(void)tencentDidNotNetWork  
  24. {  
  25.     _labelTitle.text=@"无网络连接,请设置网络";  
  26. }  
  27. </span></span>  


5,如果代码能走到登录完成这里,并且获得了accesstoken,那说明我们的登录流程就走完了,剩下的旧是获取用户具体的信息了,如昵称,城市等等;

6,如何获取昵称呢,文档提供了这样一个方法

[objc]  view plain copy print ?
  1. <span style="font-size:14px;"><span style="font-size:18px;"> [_tencentOAuth getUserInfo];</span></span>  

但是返回类型是个BOOL类似,很多朋友就郁闷了,这是什么情况,经过看代码,发现如果开发者调用了这个方法,如果成功则会实现下面协议TencentSessionDelegate里面的回调函数:

[objc]  view plain copy print ?
  1. <span style="font-size:14px;"><span style="font-size:18px;">-(void)getUserInfoResponse:(APIResponse *)response  
  2. {  
  3.  //   NSLog(@"respons:%@",response.jsonResponse);  
  4.       
  5.     self.name.text = [response.jsonResponse objectForKey:@"nickname"];  
  6. }  
  7. </span></span>  


这样就能得到我们想要的昵称等信息,到这里就算完成了我们的QQ登录授权了,剩下的就是发给后台这些登录信息,并且保持授权成功后的token等,看官方文档说明。


二,新浪微博登录授权开发:

1,同样和QQ一样,配置Url Schemes,如:wb2045436852,然后根据官方文档接入SDK等信息;

2,同样在AppDelegate.m 中实现下面回调:

[objc]  view plain copy print ?
  1. <span style="font-size:14px;">- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation  
  2. {  
  3.     return [TencentOAuth HandleOpenURL:url] || [WeiboSDK handleOpenURL:url delegate:self];  
  4. }  
  5.   
  6. - (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url  
  7. {  
  8.     return [TencentOAuth HandleOpenURL:url] || [WeiboSDK handleOpenURL:url delegate:self];  
  9. }  
  10. </span>  
3,关于新浪微博的成功登录回调是写在该类中来实现,因为这里写入了self,如果你需要到别的类中实现,可在这里做修改即可

[objc]  view plain copy print ?
  1. <span style="font-size:14px;">[WeiboSDK handleOpenURL:url delegate:self];</span>  
实现的协议为:WeiboSDKDelegate,协议方法:

[objc]  view plain copy print ?
  1. <span style="font-size:14px;">-(void)didReceiveWeiboResponse:(WBBaseResponse *)response  
  2. {  
  3.     if ([response isKindOfClass:WBAuthorizeResponse.class])  
  4.     {        
  5.         if ((int)response.statusCode == 0) {  
  6.             NSDictionary *dic = @{@"userID":[(WBAuthorizeResponse *)response userID],  
  7.                                   @"accessToken" :[(WBAuthorizeResponse *)response accessToken]};        }         
  8.     }  
  9. }  
  10. </span>  
如果能得到这个userID,token就说明登录成功了。

4,登录代码:

[objc]  view plain copy print ?
  1. <span style="font-size:14px;">- (IBAction)sinaLogin:(id)sender  
  2. {  
  3.     [WeiboSDK enableDebugMode:YES];  
  4.     [WeiboSDK registerApp:kSINA_KEY];  
  5.   
  6.     WBAuthorizeRequest *request = [WBAuthorizeRequest request];  
  7.     request.redirectURI = kRedirectURI;  
  8.     request.scope = @"all";  
  9.     request.userInfo = @{@"myKey"@"myValue"};  
  10.     [WeiboSDK sendRequest:request];  
  11. }  
  12. </span>  

这里包含了注册,打开调试log,还包括了回调地址,用户自定义提交的info等,如果登录后能正确回调AppDelegate里面的接收函数,说明我们的新娘微博登录也就成功了,剩下的就是保存相关信息和提交给后台了,值得注意的是如果你的Bundle identifier要和申请key时候一样,不然就修改你的demo的Bundle identifier 为新浪微博官方demo的Bundle identifier,并用它的key做测试,等自己的申请成功后可替换再次调试;


评价:两个平台接入后实现功能都是非常的丰富,但是从开发者角度来说,QQ登录授权方式相比比较简单,集成测试费时间较少,但是demo代码非常难看懂,甚至官方文档有代码误导,让调试异常困难,而新浪微博登录授权demo代码异常简洁明了,非常容易理解,在这代码书写方面,新浪微博的开发者胜过QQ的开发者好几条街,但是新浪微博的登录成功回调写的比较落后,需要在AppDelegate里面获取,没有QQ回调方便,而且新浪登录授权绑定了Bundle identifier,这里就让人非常的费解,耗时测试非常不爽,两家风格各异吧,但是总体来说还算顺利,当然了如果不想单独集成两家的登录授权,可推荐百度开发平台去集成他们的登录SDK,这个SDK集成了各大主流平台,如QQ,新浪微博,人人网等。

这里是成功后的截图:


后记:这里只是为同样开发的朋友们提供一点笔者开发中遇到的问题,如需QQ和新浪微博授权登录的demo代码,可发邮件给我:[email protected],进一步讨论。


转载:http://blog.csdn.net/mapboo/article/details/39202691

你可能感兴趣的:(基于第三方QQ授权登录和新浪微博授权登录的iOS代码分析)