好家伙,补补补
(资料图片)
顶不住了,跑不掉了,这部分的知识还是要补上
来看看微信小程序登录的完整流程
最左边的一列就是前端负责的部分了
几个关键的参数:
code:一个用户登录凭证,就是一个临时的token
Appid:appid 是微信账号的唯一标识,这个是固定不变的;如果了解微信公众号开发的就需要注意一下,小程序的appid 和 公众号的appid 是不一致的
OpenID:为了识别用户,每个用户针对每个公众号或小程序等应用会产生一个安全的OpenID,
公众号或应用可将此ID进行存储,便于用户下次登录时辨识其身份,或将其与用户在第三方应用中的原有账号进行绑定
同一个用户在不同的小程序中拥有不同的openid。因此,在开发小程序时,不能使用openid来进行用户的唯一性判断。
UnionId:UnionId也是用户的标识符,但它与OpenID不同的是,同一个微信用户,
登录同一个开发主体下的多个小程序或公众号的时候,分配的UnionId是一样的。
session_key:涉及数据安全的一个秘钥
我们去看一下几个关键的Api
调用接口获取登录凭证(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) } }})发起 HTTPS 网络请求。使用前请注意阅读相关说明。
示例代码:
wx.request({ url: "example.php", //仅为示例,并非真实的接口地址 data: { x: "", y: "" }, header: { "content-type": "application/json" // 默认值 }, success (res) { console.log(res.data) }})
关键词:
X 关闭
X 关闭