第140篇:微信小程序的登录流程

好家伙,补补补

 

顶不住了,跑不掉了,这部分的知识还是要补上

 

来看看微信小程序登录的完整流程

 

最左边的一列就是前端负责的部分了

几个关键的参数:

code:一个用户登录凭证,就是一个临时的token

Appidappid 是微信账号的唯一标识,这个是固定不变的;如果了解微信公众号开发的就需要注意一下,小程序的appid 和 公众号的appid 是不一致的

 

OpenID:为了识别用户,每个用户针对每个公众号或小程序等应用会产生一个安全的OpenID,

公众号或应用可将此ID进行存储,便于用户下次登录时辨识其身份,或将其与用户在第三方应用中的原有账号进行绑定

同一个用户在不同的小程序中拥有不同的openid。因此,在开发小程序时,不能使用openid来进行用户的唯一性判断。


UnionId:UnionId也是用户的标识符,但它与OpenID不同的是,同一个微信用户,

登录同一个开发主体下的多个小程序或公众号的时候,分配的UnionId是一样的。

 

session_key:涉及数据安全的一个秘钥

 

我们去看一下几个关键的Api

 

1.wx.login()

功能描述

调用接口获取登录凭证(code)。通过凭证进而换取用户登录态信息,包括用户在当前小程序的唯一标识(openid)、微信开放平台帐号下的唯一标识(unionid,若当前小程序已绑定到微信开放平台帐号)及本次登录的会话密钥(session_key)等。用户数据的加解密通讯需要依赖会话密钥完成。

参数:

 这里来看看这个code,有效期五分钟,用code换取openid,

这个code就是个临时token,要带着这个东西发请求去后端拿东西

 

示例代码:

wx.login({
  success (res) {
    if (res.code) {
      //发起网络请求
      wx.request({
        url: 'https://example.com/onLogin',
        data: {
          code: res.code
        }
      })
    } else {
      console.log('登录失败!' + res.errMsg)
    }
  }
})

 

2.wx.request()

功能描述

发起 HTTPS 网络请求。使用前请注意阅读相关说明

 

示例代码:

wx.request({
  url: 'example.php', //仅为示例,并非真实的接口地址
  data: {
    x: '',
    y: ''
  },
  header: {
    'content-type': 'application/json' // 默认值
  },
  success (res) {
    console.log(res.data)
  }
})

 

posted @ 2023-05-14 22:21  养肥胖虎  阅读(300)  评论(0编辑  收藏  举报