第三方微信受权登陆的iOS代码分析

微信已经深刻到每个App的缝隙,最经常使用的莫过度享和登陆了,接下来就以代码的形式来展开微信登陆的相关说明,至于原理级别的Oauth2.0认证体系请参考微信开放平台的相关说明和图示 。api

微信登陆受权开发微信

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

1411370441623372.png

2. 和QQ相似,须要填写Url Schemes,如demo中的wxd930ea5d5a258f4f ,而后引入相应framework;app

3. 在AppDelegate中注册和实现受权后的回调函数,代码以下:async

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来获取用户的相关信息;函数

下面用代码来实现:url

第一步:codespa

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和openidcode

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    
{    
         
     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    
{    
         
     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;  
                  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,新浪微博,微信的真机运行成功截图:

1411370706501686.png

评价:微信的开发文档相比容易理解和调试,虽然没有demo,可是文档比较详细,因此能够在必定程度上减轻了开发的困难,可是相比之下微信的受权步骤比较麻烦,须要三步才能完全获取用户信息,这点没有QQ和新浪微博简洁,须要有必定的阅读和代码功底,但愿能给你们带来帮助。

相关文章
相关标签/搜索