AD:靠谱的微信小程序外包开发

admin

admin

发表于 2017-02-06 13:17:27

wx.login详解-登录-开放接口API-微信小程序API-微信 小程序开发教程



wx.login(OBJECT)

调用接口获取登录凭证(code)进而换取用户登录态信息,包括用户的唯一标识(openid) 及本次登录的 会话密钥(session_key)用户数据的加解密通讯需要依赖会话密钥完成。

OBJECT参数说明:

参数名类型必填说明
successFunction接口调用成功的回调函数
failFunction接口调用失败的回调函数
completeFunction接口调用结束的回调函数(调用成功、失败都会执行)

success返回参数说明:

参数名类型说明
errMsgString调用结果
codeString用户允许登录后,回调内容会带上 code(有效期五分钟),开发者需要将 code 发送到开发者服务器后台,使用code 换取 session_key api,将 code 换成 openid 和 session_key

示例代码:

//app.jsApp({
  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

请求参数:

参数必填说明
appid小程序唯一标识
secret小程序的 app secret
js_code登录时获取的 code
grant_type填写为 authorization_code

返回参数:

参数说明
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 ,用于后续通信使用。

登录时序图


扩展阅读:

登录详解-开放接口API-微信小程序API-微信 小程序开发教程

wx.login详解-登录-开放接口API-微信小程序API-微信 小程序开发教程

wx.checkSession详解-登录-开放接口API-微信小程序API-微信 小程序开发教程

签名加密详解-登录-开放接口API-微信小程序API-微信 小程序开发教程


891阅读 | 0评论
你的回应