微信小程式API 登入


wx.login(OBJECT)


呼叫介面取得登入憑證(code)進而換取使用者登入態訊息,包括使用者的唯一識別(openid) 及本次登入的會話金鑰(session_key)使用者資料的加解密通訊需要依賴會話金鑰完成。


OBJECT參數說明:

QQ截图20170208150445.png

#success傳回參數說明:

QQ截图20170208150502.png

範例程式碼:

//app.js
App({
  onLaunch: function() {
    wx.login({
      success: function(res) {
        if (res.code) {
          //发起网络请求
          wx.request({
            url: 'https://test.com/onLogin',
            data: {
              code: res.code
            }
          })
        } else {
          console.log('获取用户登录态失败!' + res.errMsg)
        }
      }
    });
  }
})


code 換取session_key

這是一個HTTPS 接口,開發者伺服器使用登入憑證code 來取得session_key 和openid。其中 session_key 是對使用者資料進行加密簽章的金鑰。為了自身應用安全,session_key 不應該在網路上傳輸

介面位址:

https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code=JSCODE&grant_type=authorization_code

請求參數:

QQ截图20170208150550.png

##傳回參數:

參數#說明openid使用者唯一標識session_key#會話金鑰

傳回說明:

//正常返回的JSON数据包
{
      "openid": "OPENID",
      "session_key": "SESSIONKEY"
}
//错误时返回JSON数据包(示例为Code无效)
{
    "errcode": 40029,
    "errmsg": "invalid code"
}


登入態維護

透過wx.login() 取得到使用者登入態之後,需要維護登入態。開發者要注意不應該直接把 session_key、openid 等欄位當作使用者的識別或 session 的識別,而應該自己派發一個 session 登入態(請參考登入時序圖)。對於開發者自己產生的 session,應該保證其安全性且不應該設定較長的過期時間。 session 派發到小程式用戶端之後,可儲存在 storage ,用於後續通訊使用。


登入時序圖

1483582545198711.png

#wx.checkSession(OBJECT)


檢查登陸態是否過期

QQ截图20170208150633.png

範例程式碼:

wx.checkSession({
  success: function(){    //登录态未过期
  },
  fail: function(){    //登录态过期
    wx.login()
  }
})


##Bug & Tip

  1. bug: iOS/Android 6.3.30,在App.onLaunch 呼叫wx.login 會出現例外狀況;