基于第三方微信授权登录的iOS代码分析

http://www.cocoachina.com/ios/20140922/9715.html

微信已经深入到每一个APP的缝隙,最常用的莫过分享和登录了,接下来就以代码的形式来展开微信登录的相关说明,至于原理级别的oauth2.0认证体系请参考微信开放平台的相关说明和图示 https://open.weixin.qq.com/

微信登录授权开发

1,到微信开发平台注册相关APP,现在是等待审核成功后才能获取到对应的key和secret;获取成功后需要单独申请开通登录和支付接口,如图

2,和QQ类似,需要填写Url Schemes,如demo中的wxd930ea5d5a258f4f ,然后引入相应framework;

3,在AppDelegate中注册和实现授权后的回调函数,代码如下:


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

//向微信注册  

  [WXApi registerApp:kWXAPP_ID withDescription:@"weixin"];  

  

//授权后回调 WXApiDelegate  

-(void)onResp:(BaseReq *)resp  

{  

   /* 

    ErrCode ERR_OK = 0(用户同意) 

    ERR_AUTH_DENIED = -4(用户拒绝授权) 

    ERR_USER_CANCEL = -2(用户取消) 

    code    用户换取access_token的code,仅在ErrCode为0时有效 

    state   第三方程序发送时用来标识其请求的唯一性的标志,由第三方程序调用sendReq时传入,由微信终端回传,state字符串长度不能超过1K 

    lang    微信客户端当前语言 

    country 微信用户当前国家信息 

    */

    SendAuthResp *aresp = (SendAuthResp *)resp;  

    if (aresp.errCode== 0) {  

        NSString *code = aresp.code;  

        NSDictionary *dic = @{@"code":code};  

    }  

}  

//和QQ,新浪并列回调句柄

- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation  

{  

    return [TencentOAuth HandleOpenURL:url] ||  

    [WeiboSDK handleOpenURL:url delegate:self] ||  

    [WXApi handleOpenURL:url delegate:self];;  

}  

  

- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url  

{  

    return [TencentOAuth HandleOpenURL:url] ||  

    [WeiboSDK handleOpenURL:url delegate:self] ||  

    [WXApi handleOpenURL:url delegate:self];;  

}

4,微信登录授权比较复杂,相比QQ,新浪多了几步,简单说就是需要三步,第一步,获取code,这个用来获取token,第二步,就是带上code获取token,第三步,根据第二步获取的token和openid来获取用户的相关信息;

下面用代码来实现:

第一步:code


1

2

3

4

5

6

7

8

9

10

11

12

- (IBAction)weixinLogin:(id)sender  

{  

    [self sendAuthRequest];  

}  

  

-(void)sendAuthRequest  

{  

    SendAuthReq* req =[[SendAuthReq alloc ] init];  

    req.scope = @"snsapi_userinfo,snsapi_base";  

    req.state = @"0744" ;  

    [WXApi sendReq:req];  

}

这里获取后会调用之前在AppDelegate里面的对应oauthResp回调,获得得到的code。

第二步:token和openid


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

-(void)getAccess_token  

{  

    //https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code

      

    NSString *url =[NSString stringWithFormat:@"https://api.weixin.qq.com/sns/oauth2/access_token?appid=%@&secret=%@&code=%@&grant_type=authorization_code",kWXAPP_ID,kWXAPP_SECRET,self.wxCode.text];  

      

    dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{  

        NSURL *zoneUrl = [NSURL URLWithString:url];  

        NSString *zoneStr = [NSString stringWithContentsOfURL:zoneUrl encoding:NSUTF8StringEncoding error:nil];  

        NSData *data = [zoneStr dataUsingEncoding:NSUTF8StringEncoding];  

        dispatch_async(dispatch_get_main_queue(), ^{  

            if (data) {  

                NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableContainers error:nil];  

              /* 

               

               "access_token" = "OezXcEiiBSKSxW0eoylIeJDUKD6z6dmr42JANLPjNN7Kaf3e4GZ2OncrCfiKnGWiusJMZwzQU8kXcnT1hNs_ykAFDfDEuNp6waj-bDdepEzooL_k1vb7EQzhP8plTbD0AgR8zCRi1It3eNS7yRyd5A"; 

               "expires_in" = 7200; 

               openid = oyAaTjsDx7pl4Q42O3sDzDtA7gZs; 

               "refresh_token" = "OezXcEiiBSKSxW0eoylIeJDUKD6z6dmr42JANLPjNN7Kaf3e4GZ2OncrCfiKnGWi2ZzH_XfVVxZbmha9oSFnKAhFsS0iyARkXCa7zPu4MqVRdwyb8J16V8cWw7oNIff0l-5F-4-GJwD8MopmjHXKiA"; 

               scope = "snsapi_userinfo,snsapi_base"; 

               

               */

                  

                self.access_token.text = [dic objectForKey:@"access_token"];  

                self.openid.text = [dic objectForKey:@"openid"];  

                

            }  

        });  

    });  

}

利用GCD来获取对应的token和openID.

第三步:userinfo


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

-(void)getUserInfo  

{  

   // https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID

      

    NSString *url =[NSString stringWithFormat:@"https://api.weixin.qq.com/sns/userinfo?access_token=%@&openid=%@",self.access_token.text,self.openid.text];  

      

    dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{  

        NSURL *zoneUrl = [NSURL URLWithString:url];  

        NSString *zoneStr = [NSString stringWithContentsOfURL:zoneUrl encoding:NSUTF8StringEncoding error:nil];  

        NSData *data = [zoneStr dataUsingEncoding:NSUTF8StringEncoding];  

        dispatch_async(dispatch_get_main_queue(), ^{  

            if (data) {  

                NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableContainers error:nil];  

                /* 

                 

                 city = Haidian; 

                 country = CN; 

                 headimgurl = "http://wx.qlogo.cn/mmopen/FrdAUicrPIibcpGzxuD0kjfnvc2klwzQ62a1brlWq1sjNfWREia6W8Cf8kNCbErowsSUcGSIltXTqrhQgPEibYakpl5EokGMibMPU/0"; 

                 language = "zh_CN"; 

                 nickname = "xxx"; 

                 openid = oyAaTjsDx7pl4xxxxxxx; 

                 privilege =     ( 

                 ); 

                 province = Beijing; 

                 sex = 1; 

                 unionid = oyAaTjsxxxxxxQ42O3xxxxxxs; 

                 

                 */

                  

                self.nickname.text = [dic objectForKey:@"nickname"];  

                self.wxHeadImg.image = [UIImage imageWithData:[NSData dataWithContentsOfURL:[NSURL URLWithString:[dic objectForKey:@"headimgurl"]]]];  

  

            }  

        });  

  

    });  

}

执行到这一步就算完成了整个授权登录的功能,能把昵称和头像显示出来,剩下的就是及时刷新你的token,详情可参考开发文档。

下面是登录成功后的QQ,新浪微博,微信的真机运行成功截图:

评价:微信的开发文档相比容易理解和调试,虽然没有demo,但是文档比较详细,所以可以在一定程度上减轻了开发的困难,但是相比之下微信的授权步骤比较麻 烦,需要三步才能彻底获取用户信息,这点没有QQ和新浪微博简洁,需要有一定的阅读和代码功底,希望能给大家带来帮助。

时间: 2024-10-13 23:25:23

基于第三方微信授权登录的iOS代码分析的相关文章

iOS疯狂详解之第三方微信授权登录的iOS代码分析

微信已经深入到每一个APP的缝隙,最常用的莫过分享和登录了,接下来就以代码的形式来展开微信登录的相关说明,至于原理级别的oauth2.0认证体系请参考微信开放平台的相关说明和图示 https://open.weixin.qq.com/ 微信登录授权开发 1,到微信开发平台注册相关APP,现在是等待审核成功后才能获取到对应的key和secret:获取成功后需要单独申请开通登录和支付接口,如图 2,和QQ类似,需要填写Url Schemes,如demo中的wxd930ea5d5a258f4f ,然后

第三方微信授权登录的iOS代码分析

微信已经深入到每一个App的缝隙,最常用的莫过分享和登录了,接下来就以代码的形式来展开微信登录的相关说明,至于原理级别的Oauth2.0认证体系请参考微信开放平台的相关说明和图示 . 微信登录授权开发 1. 到微信开发平台注册相关APP,现在是等待审核成功后才能获取到对应的key和secret:获取成功后需要单独申请开通登录和支付接口,如图 2. 和QQ类似,需要填写Url Schemes,如demo中的wxd930ea5d5a258f4f ,然后引入相应framework: 3. 在AppDe

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

基于iOS实现APP的第三方登陆之QQ和新浪微博授权,在开发中明显能感觉到两家SDK的差异和易用性,这里先赘述下接入第三方SDK时的一个基本的步骤: 1,确定用需中需要这样一个功能,如果QQ登录,似乎主流了,APP注册标配啊: 2,找到相关的开放平台,如QQ互联平台,http://connect.qq.com/: 3,注册成功后创建自己的APP,填写一堆基本信号后获得一个App_Key,就是你APP的唯一识别码: 3,下载对应的SDK,并且阅读其中的开发文档或demo,通常看开发文档比较直观,如

第三方微信授权登录iOS代码解析

而今微信已经深入到了每一个手机之中,是每款手机必备的APP,我们最常用的莫过于分享和登录.接下来我们来看看微信登录的相关说明. 微信登录授权开发 1.可以到微信开发平台注册相关的APP,等待审核成功后可获得对应的key和secret,获取成功后需要单独申请开通登录和支付接口,如图所示: 2.和QQ比较类似,需要填写Url Schemes,如demo中的wxd930ea5d5a258f4f ,然后引入相应framework. 3.在AppDelegate中注册和实现授权后的回调函数,代码如下: 0

iOS 基于第三方QQ授权登录

基于iOS实现APP的第三方QQ登陆,接入第三方SDK时的一个基本的步骤: 1,找到相关的开放平台,QQ互联平台,http://connect.qq.com/: 2,注册成功后创建自己的APP,填写一堆基本信号后获得一个App_Key,就是你APP的唯一识别码: 3,下载对应的SDK,并且阅读其中的开发文档或demo,通常看开发文档比较直观,如果看demo,有些SDK的demo简直不忍直视: 4,嵌入SDK中对应功能,测试成功后提交第三方平台审核,等审核通过后就可以正式接入第三方SDK的功能了:

基于OAuth2.0协议的QQ第三方授权登录iOS代码分析

简要说明: 授权登录已经成为注册方式里的主流,目前授权登录方式主要SSO跳转授权登录和OAuth2.0两种,前者好处无需用户再次输入密码就可以直接授权成功,但前提是必须用户手机端安装了该软件,比如QQ,后者的优势就是是否安装无关紧要,是一个HTML的页面呈现,麻烦就在于要输入用户名和密码,这就非常不爽了,但是有时候偏偏必须这么做,理由嘛,自行想想就好,接下来我们就看看如果利用OAuth2.0的方式来做QQ授权登录,如果想了解QQ的SSO授权登录,可以看我(博客主页)之前的博客:基于第三方QQ授权

关于微信授权登录并获取Openid以及用户信息

一.集成微信授权登录 二.集成代码 1. AppDelegate 代码 #import "AppDelegate.h"#import "WXApi.h"#import "WXApiManager.h"@interface AppDelegate () @end @implementation AppDelegate - (BOOL)application:(UIApplication *)application didFinishLaunchin

微信授权登录并获取用户信息接口开发

总结一下微信授权登录并获取用户信息 这个接口的开发流程. 一.首先你的微信公众号要获得相应的AppID和AppSecret,申请微信登录且通过审核后,才可开始接入流程. 二.授权流程 1.流程说明 (1). 第三方发起微信授权登录请求,微信用户允许授权第三方应用后,微信会拉起应用或重定向到第三方网站,并且带上授权临时票据code参数: (2). 通过code参数加上AppID和AppSecret等,通过API换取access_token: (3). 通过access_token进行接口调用,获取

微信授权登录(PHP)

微信授权登录(PHP) 微信授权 OAuth2.0授权 微信网页授权 主要是在项目中遇到网页授权登录这个需求,就对此做些总结记录. OAuth2.0授权 OAuth是一个开放协议,允许用户让第三方应用以安全且标准的方式获取该用户在某一网站.移动或桌面应用上存储的个人信息,而无需将用户名和密码提供给第三方应用.常见微信.QQ登录,省去管理账户的麻烦,也不会造成用户的流失. 打开微信的官方文档,会看到网页授权一些说明.(有点摸不着头脑,主要是当时没能关联起来,微信文档每次看都那么郁闷!!!) 来了解