本节主要是说下怎样识别一个小程序的用户,需要用什么数据来做标识呢;
我们应该都知道判断是不是一个用户大部分都是通过userid来判断,如果这个用户访问的应用发送了一个请求,把userid之类的数据发给了服务器,我们可以通过这个字段来确定这是不是一个用户,如果没有这个值的话可能就是一个游客了,但是在微信里的小程序我们怎样拿到这样的id呢?
其实在小程序里当用户访问的时候我们可以借助小程序的api能力获取到一个针对当前小程序的用户id ,他是openid,而且针对同一个小程序同一个人是永远不会改变的,那我们就可以把openid作为一个用户来识别,也可以根据openid 改造成只支持已有的用户体系;
具体怎么实现呢?
这里需要借助后端api的支持,比如php java node等;api的域名需要在小程序后台进行安全域名配置才,然后线上必须是https协议;
官方提供了相关的api:小程序可以通过微信官方提供的登录能力方便地获取微信提供的用户身份标识,快速建立小程序内的用户体系。
首先小程序api文档提供了一个wx.login的方法,这个方法是小程序提供的,我们在调用这个api回调中处理返回的数据;
-
小程序调用wx.login() 获取 临时登录凭证code ,并回传到开发者服务器,其实就是把code传给自己的后端接口
-
开发者服务器以code换取 用户唯一标识openid 和 会话密钥session_key。意思就是后端接口使用code获取openid喝sessionkey,sessionkey什么意思呢,简单的说下就是是对用户数据进行加密签名的密钥,可以解密数据;
之后开发者服务器可以根据用户标识来生成自定义登录态,用于后续业务逻辑中前后端交互时识别用户身份。
然后继续 下一步 就是
登录凭证校验 临时登录凭证校验接口是一个 HTTPS 接口,开发者服务器(后端api)使用 临时登录凭证code 获取 session_key 和 openid 等
这个时候时候后端api就可以获得openid了,拿到了当前访问小程序用户的标识;基本流程就是这样的;
而且这个过程是用户无感之的,我们可以在小程序启动的时候 在app onshow的声明周期内完成这个逻辑处理,将openid放到全局变量或者本地缓存;以方便后续使用;
然后有了这个能力后我们就可以完成很多有趣的功能了,比如记录邀请关系 ,分销等(微信发现了会被封的)目前很多应用内都有这样的类似的功能,本质都是一样的。
好了,我这里只是分享了一个实现的思路,具体的官方文档也写了,如果有不明白的地方可以留言交流。
今天就到这里了,请记住,我是智哥,用自己的经验分享有用的东西,拜拜!!