• 微信小程序之登录态维护(十一)


    【未经作者本人同意,请勿以任何形式转载】

    》什么是登录态?

    所谓登录态,就是程序在运行时,能够识别当前用户,能够证明自己的唯一性且合法。

    我们知道,WEB服务器通过浏览器携带的cookie获取session来判断是否是同一用户(或浏览器);Restful服务通过客户端传过来唯一ID,来识别调用用户。

    》为什么需要维护登录态?

    • 有自身用户体系的应用
    • 用户敏感数据,只对用户可见
    • 涉及用户相关的业务,比如我的订单、个性化推荐等

    》小程序登录态维护实现流程

    1. 通过wx.login获取登录态。
    2. 通过登录返回的code发送给服务器,服务器用code换取session_key和openid后。
    3. 获取session_key后一般使用缓存框架保存登录态,服务端随机生成一串唯一字符串3rdSessionId为key,session_key为value组成键值对并存到缓存当中,缓存时间视情况自行决定。
    4. 将3rdSessionId返回给客户端
    5. 客户端将3rdSessionId缓存到localStorage中,后续接口从缓存中读取3rdSessionId,传递给服务器;服务器根据3rdSessionId来判断用户身份。
    6. 如果服务器根据3rdSessionId在缓存中查找是否存在session_key,如果存在正常执行;如果不存在小程序未登录,重新从第一步流程走。

    以上流程是官方推荐使用的流程,并不是维护登录态的唯一途径。

    另外,你也可以在小程序中使用wx.checkSession()检查登录态是否过期。如果过期重新调用wx.login接口。
    session_key在微信服务器有效期是30天,建议服务端缓存session_key不超过30天。

    你也可以关注我的微信公众号『ITNotes』, 一起交流学习 。

  • 相关阅读:
    COCI2013-2014 Contest#3 F 单调栈
    Topcoder SRM568 Div1 DisjointSemicircles (二分图染色)
    COCI2013-2014 Contest#1 F SLASTIČAR
    TopCoder SRM 561 Orienteering(树形dp)
    COCI20122013 Contest#5 F
    2016 多校5 ATM
    2014多校6 Another Letter Tree
    HAOI2015 数组游戏
    [CCO 2017]接雨滴
    Luogu P6789 寒妖王
  • 原文地址:https://www.cnblogs.com/nosqlcoco/p/6242316.html
Copyright © 2020-2023  润新知