项目地址 :    https://github.com/zhonggaorong/weixinLoginDemo

最新版本的微信登录实现步骤实现:

1.在进行微信OAuth2.0授权登录接入之前,在微信开放平台注册开发者帐号,并拥有一个已审核通过的移动应用,并获得相应的AppID和AppSecret,申请微信登录且通过审核后,可开始接入流程。 地址: 点击打开链接

 

2. 下载最新的SDK   地址: 点击打开链接

SDK内容如下:

结构解析:

从上到下依次说明:

1. 静态库,直接拖入工程。

2. ready.text自己看

3. 授权SDK。

4. 登录方法所在类。

5.  一些常用的对象类。

iOS微信登录注意事项:

  1. 1、目前移动应用上微信登录只提供原生的登录方式,需要用户安装微信客户端才能配合使用。
  2. 2、对于Android应用,建议总是显示微信登录按钮,当用户手机没有安装微信客户端时,请引导用户下载安装微信客户端。
  3. 3、对于iOS应用,考虑到iOS应用商店审核指南中的相关规定,建议开发者接入微信登录时,先检测用户手机是否已安装微信客户端(使用sdk中isWXAppInstalled函数 ),对未安装的用户隐藏微信登录按钮,只提供其他登录方式(比如手机号注册登录、游客登录等)。

iOS微信登录大致流程:

  1. 1. 第三方发起微信授权登录请求,微信用户允许授权第三方应用后,微信会拉起应用或重定向到第三方网站,并且带上授权临时票据code参数;
  2. 2. 通过code参数加上AppID和AppSecret等,通过API换取access_token;
  3. 3. 通过access_token进行接口调用,获取用户基本数据资源或帮助用户实现基本操作。

示意图:

接下来就进入正题:

1.配置工程

1. 新建一个工程。 
        2. 把下载下来的sdk中的.h文件与静态库全部拖入工程。

         3.  加入依赖库
         4.  URL - Types  (加入 appid)
        target  -  Info - URL Types
        
 
         5. 白名单
当程序出现此错误

  1. -canOpenURL: failed for URL: "weixin://app/wx5efead4057f98bc0/" - error: "This app is not allowed to query for scheme weixin"

就说明没有针对iOS9 增加白名单。在info.plist文件中加入 LSApplicationQueriesSchemes

App Transport Security 这个是让程序还是用http进行请求。
LSApplicationQueriesSchemes 这个是增加微信的白名单。
         6.  现在编译应该是没有问题了。
 
2. 终于到令人兴奋的代码部分了。 直接上代码。
  1. //
  2. //  AppDelegate.m
  3. //  weixinLoginDemo
  4. //
  5. //  Created by 张国荣 on 16/6/20.
  6. //  Copyright © 2016年 BateOrganization. All rights reserved.
  7. //
  8. #import "AppDelegate.h"
  9. #import "WXApi.h"
  10. //微信开发者ID
  11. #define URL_APPID @"app id"
  12. @end
  13. @implementation AppDelegate
  14. - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
  15. //向微信注册应用。
  16. [WXApi registerApp:URL_APPID withDescription:@"wechat"];
  17. return YES;
  18. }
  19. -(BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString *,id> *)options{
  20. /*! @brief 处理微信通过URL启动App时传递的数据
  21. *
  22. * 需要在 application:openURL:sourceApplication:annotation:或者application:handleOpenURL中调用。
  23. * @param url 微信启动第三方应用时传递过来的URL
  24. * @param delegate  WXApiDelegate对象,用来接收微信触发的消息。
  25. * @return 成功返回YES,失败返回NO。
  26. */
  27. return [WXApi handleOpenURL:url delegate:self];
  28. }
  29. /*! 微信回调,不管是登录还是分享成功与否,都是走这个方法 @brief 发送一个sendReq后,收到微信的回应
  30. *
  31. * 收到一个来自微信的处理结果。调用一次sendReq后会收到onResp。
  32. * 可能收到的处理结果有SendMessageToWXResp、SendAuthResp等。
  33. * @param resp具体的回应内容,是自动释放的
  34. */
  35. -(void) onResp:(BaseResp*)resp{
  36. NSLog(@"resp %d",resp.errCode);
  37. /*
  38. enum  WXErrCode {
  39. WXSuccess           = 0,    成功
  40. WXErrCodeCommon     = -1,  普通错误类型
  41. WXErrCodeUserCancel = -2,    用户点击取消并返回
  42. WXErrCodeSentFail   = -3,   发送失败
  43. WXErrCodeAuthDeny   = -4,    授权失败
  44. WXErrCodeUnsupport  = -5,   微信不支持
  45. };
  46. */
  47. if ([resp isKindOfClass:[SendAuthResp class]]) {   //授权登录的类。
  48. if (resp.errCode == 0) {  //成功。
  49. //这里处理回调的方法 。 通过代理吧对应的登录消息传送过去。
  50. if ([_wxDelegate respondsToSelector:@selector(loginSuccessByCode:)]) {
  51. SendAuthResp *resp2 = (SendAuthResp *)resp;
  52. [_wxDelegate loginSuccessByCode:resp2.code];
  53. }
  54. }else{ //失败
  55. NSLog(@"error %@",resp.errStr);
  56. UIAlertView *alert = [[UIAlertView alloc]initWithTitle:@"登录失败" message:[NSString stringWithFormat:@"reason : %@",resp.errStr] delegate:self cancelButtonTitle:@"取消" otherButtonTitles:@"确定", nil nil];
  57. [alert show];
  58. }
  59. }
  60. }
  61. @end
下面是登录的类。
 
  1. //
  2. //  ViewController.m
  3. //  weixinLoginDemo
  4. //
  5. //  Created by 张国荣 on 16/6/20.
  6. //  Copyright © 2016年 BateOrganization. All rights reserved.
  7. //
  8. #import "ViewController.h"
  9. #import "WXApi.h"
  10. #import "AppDelegate.h"
  11. //微信开发者ID
  12. #define URL_APPID @"appid"
  13. #define URL_SECRET @"app secret"
  14. #import "AFNetworking.h"
  15. @interface ViewController ()<WXDelegate>
  16. {
  17. AppDelegate *appdelegate;
  18. }
  19. @end
  20. @implementation ViewController
  21. - (void)viewDidLoad {
  22. [super viewDidLoad];
  23. // Do any additional setup after loading the view, typically from a nib.
  24. }
  25. #pragma mark 微信登录
  26. - (IBAction)weixinLoginAction:(id)sender {
  27. if ([WXApi isWXAppInstalled]) {
  28. SendAuthReq *req = [[SendAuthReq alloc]init];
  29. req.scope = @"snsapi_userinfo";
  30. req.openID = URL_APPID;
  31. req.state = @"1245";
  32. appdelegate = [UIApplication sharedApplication].delegate;
  33. appdelegate.wxDelegate = self;
  34. [WXApi sendReq:req];
  35. }else{
  36. //把微信登录的按钮隐藏掉。
  37. }
  38. }
  39. #pragma mark 微信登录回调。
  40. -(void)loginSuccessByCode:(NSString *)code{
  41. NSLog(@"code %@",code);
  42. __weak typeof(*&self) weakSelf = self;
  43. AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
  44. manager.requestSerializer = [AFJSONRequestSerializer serializer];//请求
  45. manager.responseSerializer = [AFHTTPResponseSerializer serializer];//响应
  46. manager.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"text/html",@"application/json", @"text/json",@"text/plain", nil nil];
  47. //通过 appid  secret 认证code . 来发送获取 access_token的请求
  48. [manager GET:[NSString stringWithFormat:@"https://api.weixin.qq.com/sns/oauth2/access_token?appid=%@&secret=%@&code=%@&grant_type=authorization_code",URL_APPID,URL_SECRET,code] parameters:nil progress:^(NSProgress * _Nonnull downloadProgress) {
  49. } success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {  //获得access_token,然后根据access_token获取用户信息请求。
  50. NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:responseObject options:NSJSONReadingMutableContainers error:nil];
  51. NSLog(@"dic %@",dic);
  52. /*
  53. access_token   接口调用凭证
  54. expires_in access_token接口调用凭证超时时间,单位(秒)
  55. refresh_token  用户刷新access_token
  56. openid 授权用户唯一标识
  57. scope  用户授权的作用域,使用逗号(,)分隔
  58. unionid     当且仅当该移动应用已获得该用户的userinfo授权时,才会出现该字段
  59. */
  60. NSString* accessToken=[dic valueForKey:@"access_token"];
  61. NSString* openID=[dic valueForKey:@"openid"];
  62. [weakSelf requestUserInfoByToken:accessToken andOpenid:openID];
  63. } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
  64. NSLog(@"error %@",error.localizedFailureReason);
  65. }];
  66. }
  67. -(void)requestUserInfoByToken:(NSString *)token andOpenid:(NSString *)openID{
  68. AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
  69. manager.requestSerializer = [AFJSONRequestSerializer serializer];
  70. manager.responseSerializer = [AFHTTPResponseSerializer serializer];
  71. [manager GET:[NSString stringWithFormat:@"https://api.weixin.qq.com/sns/userinfo?access_token=%@&openid=%@",token,openID] parameters:nil progress:^(NSProgress * _Nonnull downloadProgress) {
  72. } success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {
  73. NSDictionary *dic = (NSDictionary *)[NSJSONSerialization JSONObjectWithData:responseObject options:NSJSONReadingMutableContainers error:nil];
  74. NSLog(@"dic  ==== %@",dic);
  75. } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
  76. NSLog(@"error %ld",(long)error.code);
  77. }];
  78. }
  79. - (void)didReceiveMemoryWarning {
  80. [super didReceiveMemoryWarning];
  81. // Dispose of any resources that can be recreated.
  82. }
  83. @end
 

大功告成。

iOS开发之第三方登录微信-- 史上最全最新第三方登录微信方式实现的更多相关文章

  1. iOS开发之第三方登录微博-- 史上最全最新第三方登录微博方式实现

    相关资源地址: 本项目demo地址 :  https://github.com/zhonggaorong/weiboSDKDemo 最新SDK下载:  最新微博SDK 官网注册地址:点击打开链接 最新 ...

  2. iOS开发之第三方登录QQ -- 史上最全最新第三方登录QQ方式实现

    项目地址 :  https://github.com/zhonggaorong/QQLoginDemo/tree/master 最新版本的qq登录实现步骤实现: 1. 首先,你需要去向腾讯申请账号. ...

  3. 史上最全最新java面试题合集二(附答案)

    下面小编整理了本套java面试题全集,分享给大家,希望对大家的java学习和就业面试有所帮助. 51.类ExampleA继承Exception,类ExampleB继承ExampleA. 有如下代码片断 ...

  4. React Native常用第三方组件汇总--史上最全 之一

    React Native 项目常用第三方组件汇总: react-native-animatable 动画 react-native-carousel 轮播 react-native-countdown ...

  5. React Native常用第三方组件汇总--史上最全[转]

    本文出处: http://blog.csdn.net/chichengjunma/article/details/52920137 React Native 项目常用第三方组件汇总: react-na ...

  6. iOS分类(category),类扩展(extension)—史上最全攻略

    背景: 在大型项目,企业级开发中多人同时维护同一个类,此时程序员A因为某项需求只想给当前类currentClass添加一个方法newMethod,那该怎么办呢? 最简单粗暴的方式是把newMethod ...

  7. 史上最全最新Java面试题合集一(附答案)

    下面小编整理了本套java面试题全集,分享给大家,希望对大家的java学习和就业面试有所帮助. 1.面向对象的特征有哪些方面? 答:面向对象的特征主要有以下几个方面: 抽象:抽象是将一类对象的共同特征 ...

  8. 开源框架】Android之史上最全最简单最有用的第三方开源库收集整理,有助于快速开发

    [原][开源框架]Android之史上最全最简单最有用的第三方开源库收集整理,有助于快速开发,欢迎各位... 时间 2015-01-05 10:08:18 我是程序猿,我为自己代言 原文  http: ...

  9. 了解iOS消息推送一文就够:史上最全iOS Push技术详解

    本文作者:陈裕发, 腾讯系统测试工程师,由腾讯WeTest整理发表. 1.引言 开发iOS系统中的Push推送,通常有以下3种情况: 1)在线Push:比如QQ.微信等IM界面处于前台时,聊天消息和指 ...

随机推荐

  1. Module中引用Module中的Activity时报错了,错误是找不到R文件中的id引用

    1.好像库modul和主modul不能有相同名字和layout文件 2.资源文件名冲突导致的

  2. php 配置文件

    <?php return array( 'TMPL_L_DELIM'=>'<{', //配置左定界符 'TMPL_R_DELIM'=>'}>', //配置右定界符 'DB ...

  3. Microsoft Azure 负载平衡服务

     Microsoft Azure 为在其中托管的虚拟机(IaaS) 和云服务(PaaS) 提供负载平衡服务.负载平衡支持应用程序伸缩,并且提供应用程序故障恢复以及其他优势. 可以通过以下方式访问负 ...

  4. HDU 5823 color II(FWT)

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5823 [题目大意] 定义一张无向图的价值:给每个节点染色使得每条边连接的两个节点颜色不相同的最少颜 ...

  5. ubuntu-12.04.4-server安装

    一.系统ISO下载      下载地址:http://www.ubuntu.com/download       根据自己的需求下载,我的电脑配置一般,因此选择32位的.   二.虚拟机配置      ...

  6. iOS中菊花。。。

    其实系统的菊花除了功能有点单一,不具有刷新页面的功能以外,其他都还好吧,满足你一些正常的提示功能还是绰绰有余的:直接把项目里面的代码粘出来吧,其实也没有什么特别要注意的地方,一些设置属性也算留个备份 ...

  7. table边框不显示

    今日在做报表的时候发现,最后一行隐藏后整个报表的下边框会不显示,猜测是td的边框隐藏后但table并未设置边框,导致下边框没有出现.因此设置了table边框后问题解决.table和td的边框关系如下实 ...

  8. Hibernate与iBATIS的比较

    1.出身 hibernate 是当前最流行的o/r mapping框架,它出身于sf.net,现在已经成为jboss的一部分了. ibatis 是另外一种优秀的o/r mapping框架,目前属于ap ...

  9. windows下fitness python版本安装测试

    FitNesse介绍¶ FitNesse是一套软件开发协作工具. 伟大的软件需要协作和交流,FitNesse可以帮助大家加强软件开发过程中的协作.能够让客户.测试人员和开发人员了解软件要做成什么样,自 ...

  10. appium 学习各种小功能总结--功能有《滑动图片、保存截图、验证元素是否存在、》---新手总结(大牛勿喷,新手互相交流)

    1.首页滑动图片点击 /** * This Method for swipe Left * 大距离滑动 width/6 除数越大向左滑动距离也越大. * width:720 *height:1280 ...