Swift開發(fā) 微信第三方登錄

引言

微信支付和微信第三方登錄已經(jīng)做過好多次了,每次做感覺都有坑,詳細(xì)記錄下,以免下次踩坑,先從微信登錄開始吧。

微信第三方登錄

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
添加相關(guān)依賴庫
  • Build Setting->Other Linker Flags中加入"-ObjC"

  • Info->URL Types中添加下圖所示(URL Schemes就是你微信開放者平臺應(yīng)用的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.在代碼中使用開發(fā)工具包

在很多的第三方登錄都會有OAuth2.0授權(quán)登錄系統(tǒng),包括微博等等,其實(shí)就是為了安全考慮,你在第三方App登錄微信賬號密碼必然不放心,所以微信給你官方的登錄界面,這樣就可以保護(hù)用戶的賬戶安全,由于微信沒有提供網(wǎng)頁登錄方式,所以必須IOS用戶必須下載微信客戶端,第三方App向微信請求來獲取用戶的基本信息。


微信文檔中的獲取access_token時(shí)序圖
2.1.注冊微信
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
        //MARK: -注冊微信
        WXApi.registerApp(WXAppID)
        return true
}
2.2.AppDelegate添加微信回調(diào)方法

添加WXApiDelegate代理

class AppDelegate: UIResponder, UIApplicationDelegate,WXApiDelegate
//  微信跳轉(zhuǎn)回調(diào)
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 {
            //調(diào)用其他SDK,例如支付寶SDK等
             WXApi.handleOpen(url, delegate: self)
        }
        return result
}
//  微信回調(diào)
func onResp(_ resp: BaseResp!){
    //  微信登錄回調(diào)
    if resp.errCode == 0 && resp.type == 0{//授權(quán)成功
        let response = resp as! SendAuthResp
        //  微信登錄成功通知          
        NotificationCenter.default.post(name: NSNotification.Name(rawValue: "WXLoginSuccessNotification"), object: response.code)
    }
}
2.3.調(diào)起微信
  • 在你想調(diào)起微信登錄的界面加上下面的代碼
override func viewDidLoad() {
    super.viewDidLoad()
    // 微信登錄通知
    NotificationCenter.default.addObserver(self,selector: #selector(WXLoginSuccess(notification:)),name: NSNotification.Name(rawValue: "WXLoginSuccessNotification"),object: nil)
}
//調(diào)起微信
func wxLoginBtnAction() {
        let urlStr = "weixin://"
        if UIApplication.shared.canOpenURL(URL.init(string: urlStr)!) {
            let req = SendAuthReq()
            //應(yīng)用授權(quán)作用域,如獲取用戶個(gè)人信息則填寫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")!)
            }
        }
}
  • 調(diào)起微信如果成功,會調(diào)用AppDelegate中
func onResp(_ resp: BaseResp!){
    //  微信登錄回調(diào)
    if resp.errCode == 0 && resp.type == 0{//授權(quán)成功
        let response = resp as! SendAuthResp
        //  微信登錄成功通知          
        NotificationCenter.default.post(name: NSNotification.Name(rawValue: "WXLoginSuccessNotification"), object: response.code)
    }
}
微信登錄回調(diào)參數(shù).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個(gè)小時(shí)的有效期,用GET的方式請求以下接口,刷新或續(xù)期access_token使用

https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=(你的APPID)&grant_type=refresh_token&refresh_token=(返回的REFRESH_TOKEN)
2.4.獲取用戶個(gè)人信息(UnionID機(jī)制)

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

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

正確的Json返回結(jié)果:

{ 
"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"
}
微信返回個(gè)人信息說明

總結(jié)

微信登錄的總體流程就是這樣的,最好把用戶信息保存,以便在App中需要使用用戶信息的時(shí)候調(diào)用。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容