美文网首页ios开发
Swift开发 微信第三方登录

Swift开发 微信第三方登录

作者: 听丶死亡在唱歌 | 来源:发表于2017-08-21 16:49 被阅读940次

引言

微信支付和微信第三方登录已经做过好多次了,每次做感觉都有坑,详细记录下,以免下次踩坑,先从微信登录开始吧。

微信第三方登录

1.集成微信SDK

1.1手动集成
  • 登录微信开放者平台->资源中心->资源下载


    微信SDK文件

    下载好了直接拖到Xcode里就可以了。

  • Build Phases->Link Binary With Libraries中添加以下依赖库
SystemConfiguration.framework
libz.dylib    
libsqlite3.0.dylib
libc++.dylib
Security.framework
CoreTelephony.framework
CFNetwork.framework
添加相关依赖库
  • Build Setting->Other Linker Flags中加入"-ObjC"

  • Info->URL Types中添加下图所示(URL Schemes就是你微信开放者平台应用的AppID)


  • 在桥接文件中添加以下代码

#import "WXApi.h"
#import "WXApiObject.h"
#import <CommonCrypto/CommonCrypto.h>
1.2 cocopods集成
pod 'WechatOpenSDK'
  • 在桥接文件中添加以下代码
#import "WXApi.h"
#import "WXApiObject.h"
#import <CommonCrypto/CommonCrypto.h>

2.在代码中使用开发工具包

在很多的第三方登录都会有OAuth2.0授权登录系统,包括微博等等,其实就是为了安全考虑,你在第三方App登录微信账号密码必然不放心,所以微信给你官方的登录界面,这样就可以保护用户的账户安全,由于微信没有提供网页登录方式,所以必须IOS用户必须下载微信客户端,第三方App向微信请求来获取用户的基本信息。


微信文档中的获取access_token时序图
2.1.注册微信
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
        //MARK: -注册微信
        WXApi.registerApp(WXAppID)
        return true
}
2.2.AppDelegate添加微信回调方法

添加WXApiDelegate代理

class AppDelegate: UIResponder, UIApplicationDelegate,WXApiDelegate
//  微信跳转回调
func application(_ app: UIApplication, open url: URL, options: [UIApplicationOpenURLOptionsKey : Any] = [:]) -> Bool {
    WXApi.handleOpen(url, delegate: self)
    return true
}
func application(_ application: UIApplication, open url: URL, sourceApplication: String?, annotation: Any) -> Bool {
    let result = UMSocialManager.default().handleOpen(url)
        if result == false {
            //调用其他SDK,例如支付宝SDK等
             WXApi.handleOpen(url, delegate: self)
        }
        return result
}
//  微信回调
func onResp(_ resp: BaseResp!){
    //  微信登录回调
    if resp.errCode == 0 && resp.type == 0{//授权成功
        let response = resp as! SendAuthResp
        //  微信登录成功通知          
        NotificationCenter.default.post(name: NSNotification.Name(rawValue: "WXLoginSuccessNotification"), object: response.code)
    }
}
2.3.调起微信
  • 在你想调起微信登录的界面加上下面的代码
override func viewDidLoad() {
    super.viewDidLoad()
    // 微信登录通知
    NotificationCenter.default.addObserver(self,selector: #selector(WXLoginSuccess(notification:)),name: NSNotification.Name(rawValue: "WXLoginSuccessNotification"),object: nil)
}
//调起微信
func wxLoginBtnAction() {
        let urlStr = "weixin://"
        if UIApplication.shared.canOpenURL(URL.init(string: urlStr)!) {
            let req = SendAuthReq()
            //应用授权作用域,如获取用户个人信息则填写snsapi_userinfo
            req.scope = "snsapi_userinfo"
            WXApi.send(req)
        }else{
            if #available(iOS 10.0, *) {
                UIApplication.shared.open(URL.init(string: "http://weixin.qq.com/r/qUQVDfDEVK0rrbRu9xG7")!, options: [:], completionHandler: nil)
            } else {
                // Fallback on earlier versions
                UIApplication.shared.openURL(URL.init(string: "http://weixin.qq.com/r/qUQVDfDEVK0rrbRu9xG7")!)
            }
        }
}
  • 调起微信如果成功,会调用AppDelegate中
func onResp(_ resp: BaseResp!){
    //  微信登录回调
    if resp.errCode == 0 && resp.type == 0{//授权成功
        let response = resp as! SendAuthResp
        //  微信登录成功通知          
        NotificationCenter.default.post(name: NSNotification.Name(rawValue: "WXLoginSuccessNotification"), object: response.code)
    }
}
微信登录回调参数.png
  • 如果用户同意(即resp.errCode等于0),我们可以获取到code。
    用GET方式请求官方获取access_token的接口:
https://api.weixin.qq.com/sns/oauth2/access_token?appid=(你的AppID)&secret=(你的AppSecret)&code=(你获取的code)&grant_type=authorization_code.
//  微信成功通知  
func WXLoginSuccess(notification:Notification) {
      let code = notification.object as! String
      let url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=\(WXAppID)&secret=\(WXAppSecret)&code=\(code)&grant_type=authorization_code"
       //获取access_token
      RequestTool.GETRequestWith(url, success: { (task, data) in
          print(data)
      }) { (task, error) in
          print(error)
      }
}

正确的返回

{ 
"access_token":"ACCESS_TOKEN", 
"expires_in":7200, 
"refresh_token":"REFRESH_TOKEN", 
"openid":"OPENID", 
"scope":"SCOPE" 
}

由于access_token只有2个小时的有效期,用GET的方式请求以下接口,刷新或续期access_token使用

https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=(你的APPID)&grant_type=refresh_token&refresh_token=(返回的REFRESH_TOKEN)
2.4.获取用户个人信息(UnionID机制)

使用GET的方式请求以下接口

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

正确的Json返回结果:

{ 
"openid":"OPENID",
"nickname":"NICKNAME",
"sex":1,
"province":"PROVINCE",
"city":"CITY",
"country":"COUNTRY",
"headimgurl": "http://wx.qlogo.cn/mmopen/g3MonUZtNHkdmzicIlibx6iaFqAc56vxLSUfpb6n5WKSYVY0ChQKkiaJSgQ1dZuTOgvLLrhJbERQQ4eMsv84eavHiaiceqxibJxCfHe/0",
"privilege":[
"PRIVILEGE1", 
"PRIVILEGE2"
],
"unionid": " o6_bmasdasdsad6_2sgVt7hMZOPfL"
}
微信返回个人信息说明

总结

微信登录的总体流程就是这样的,最好把用户信息保存,以便在App中需要使用用户信息的时候调用。

相关文章

  • android 微信登录sdk

    微信登录sdk接入方式请见,移动应用微信登录开发指南。 公司官网android国内版sdk,其中第三方登录选择微信...

  • iOS-微信的登录与分享

    微信登录与分享微信开发平台-移动应用微信登录开发指南1、首先导入微信的SDK 5、向微信终端程序注册第三方应用,并...

  • 各类接口申请及文档地址汇总

    第三方登录类 微信 适用情况:APP、PC申请地址:微信开放平台说明文档:移动应用微信登录开发指南、网站应用微信登...

  • iOS微信&QQ第三方登录

    微信第三方登录 一、注册微信开放平台开发账号 1. 微信开放平台网站:微信开放平台 2. 注册开发者账号,按步骤填...

  • Swift开发 微信第三方登录

    引言 微信支付和微信第三方登录已经做过好多次了,每次做感觉都有坑,详细记录下,以免下次踩坑,先从微信登录开始吧。 ...

  • 代码 - 收藏集 - 掘金

    安卓第三方登录之微信登录(图文详解) - Android - 掘金一、创建应用并成为开发者 1、创建应用 1)到微...

  • 微信服务号开发整体流程

    1、微信的各个平台 微信开放平台,面向开发人员,为网站、App 提供微信第三方登录功能,为 App 提供支付功能(...

  • Swift开发 微信支付

    引言 集成微信SDK就不废话了,在微信第三方登录做了介绍,传送门:微信第三方登录 签名 微信支付个人觉得最难的就是...

  • (一)微信开发-第三方平台定制服务商模式

    开发微信第三方平台-服务商模式准备步骤 第一步:注册并登录微信开放平台 第二步:登录后创建第三方平台 第三步:开始...

  • ApowerMirror——手机投屏电脑/电脑控制手机/大屏吃鸡

    一、登录注册 1、支持手机号、邮箱和第三方登录登录 2、通过第三方绑定支持微信、微博、QQ,所以也是可以通过微信、...

网友评论

本文标题:Swift开发 微信第三方登录

本文链接:https://www.haomeiwen.com/subject/ahbarxtx.html