小程序、公众号开发报code been used(40163)或invalid code(40029)错误,解决方案--之--搞清楚微信的登录机制,保存登录状态!!!

2023-05-16

📖 前言

  做微信小程序或公众号开发,有时我们为了管理用户,需要获取用户的openid,unionId等信息。这时会用到微信提供的接口:code2Session。

  code2Session接口以code ( code是前端调用wx.login接口获取的 ) 为参数之一,调用成功可返回openid和session_key。openid是小程序用户的唯一标识;session_key可作为秘钥,对wx.getUserInfo接口获取的加密数据进行解密,解密之后可以获取到用户的unionId,unionId是同主体 ( 绑定了同一个开放平台账号)下微信用户的唯一标识。

  在实际开发中,相信很多人在调接口时都遇到过这种错误:invalid code或code been used。归根结底是没搞清楚微信的登录机制,在代码逻辑上出了问题。前端频繁调用wx.login接口或后端频繁调用code2Session接口都有可能导致这些错误。

  接下来,笔者尽可能详细的列出可能会出现的坑点,帮大家在理清登录逻辑的基础上,将bug扼杀在摇篮之中!

📖 何为登录状态?

  当用户进入小程序是有 登录状态一说的,在登录状态有效期内什么是不变的呢?session_key!

  记住,登录状态有效期内,session_key是不会变化的,即使你重新调用wx.login接口获取新的code,用新code传给后台去获取session_key,你会发现获取的 session_key跟上次是一样的。

  聪明的你这时候应该知道,我们可以在后台保存session_key,在登录状态有效期内,就无需再次调用code2Session接口去获取session_key了。

📖 那么,如何检测登录状态是否有效?

  前端调用wx.checkSession接口,可查询用户当前登录状态是否有效。

  wx.checkSession({
  	success() { // 登录状态有效回调
            
 	 },
  	fail() {  // 登录状态失效回调

  	}
  })

📖 什么情况下会报code been used(40163)?

  在登录状态有效期内,后台用同一个code,多次调用code2Session接口就会报code been used(40163)错误。

📖 什么情况下会报invalid code(40029)?

  • 前端每次调用wx.login接口会导致code刷新,若后台没有及时获取到新的code,用老的code去调接口,会报错。
  • 后台代码逻辑问题:误改了前端传过来的code,会报错。

📖 如何正确的处理代码逻辑?

  • 前端可以频繁的调用wx.login接口,但每次调用要及时通知后端。这样后端也可以频繁的调用code2Session接口,只要用的最新code就不会报错。但既然我们知道了在登录有效期这个说法,为什么要频繁调接口呢?可以参考下面这种方式,也是笔者在实际项目中的鉴权机制: unionId+token双重校验 ↓
  • 1、 假设用户第一次进小程序,调用wx.checkSession检测必然为登录状态失效,我们可以用valid这个参数表示登录状态。调用wx.login接口获取code,调用getUserInfo接口获取加密数据,并把如下参数传给后台:{code:—,encryptedData:—,iv—,valid:false},后台发现valid为false的时候,就通过code获取session_key,再通过session_key解密出unionId,校验unionId是不是合法用户,如果合法,就用这个unionId生成一个token返回给前端,前端将token存入缓存。
    2、 校验成功,小程序就可以进入主页面了,后续的业务接口都把token放在请求头里,后台校验token是否合法。若发现token无效,就给前端返回你们协商好的错误码,前端跳转至登录页面(带参跳转:tokenInvalid:1),登录页面发现带有参数tokenInvalid时,即使wx.checkSession检查登录状态有效,我们也要重新获取code,加密数据,并把valid强制设为false,让后端重新校验,类似步骤1。这个逻辑就是处理token失效的情况的。(token是我们自定义的,后台可以对其设置有效期,比如1个月。)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

小程序、公众号开发报code been used(40163)或invalid code(40029)错误,解决方案--之--搞清楚微信的登录机制,保存登录状态!!! 的相关文章

  • 【逐函数详细讲解ORB_SLAM2算法和C++代码|ORBextractor|1-19】

    ORBextractor的类 xff0c 是ORB SLAM2系统中用于提取ORB特征的关键部分 在视觉SLAM xff08 Simultaneous Localization and Mapping xff09 系统中 xff0c 特征提
  • 【逐函数详细讲解ORB_SLAM2算法和C++代码|ORBmatcher|1-20】

    特征匹配是关键任务之一 xff0c 因为它们用于找到不同帧之间的特征匹配 xff0c 从而实现跟踪 地图构建和优化等任务 ORBmatcher类的主要功能如下 xff1a 在不同场景下进行特征点匹配 xff0c 例如初始化 跟踪 重定位 回
  • 【逐函数详细讲解ORB_SLAM2算法和C++代码|Optimizer|1-21】

    优化是关键任务之一 xff0c 因为它们用于提高位姿估计 地图点位置和地图一致性的精度 Optimizer类的主要功能如下 xff1a 在局部和全局范围内进行Bundle Adjustment xff08 BA xff09 优化 对当前帧进
  • 【逐函数详细讲解ORB_SLAM2算法和C++代码|PnPsolver|1-22】

    它实现了一种名为EPnP xff08 Efficient Perspective n Point xff09 的算法 xff0c 该算法能够从2D 3D点对之间的关系中估计相机的位姿 PnPsolver类的主要功能如下 xff1a 通过使用
  • 【逐函数详细讲解ORB_SLAM2算法和C++代码|Sim3Solver|1-23】

    Sim3Solver类负责估计两个关键帧之间的相似性变换 Sim 3 该类接受两个关键帧和它们之间的一组匹配的地图点作为输入 然后使用RANSAC方法迭代地优化Sim 3 变换 估计的变换包括旋转 平移和尺度信息 以下是这个头文件中使用的C
  • 驼峰命名法

    简介 xff1a 驼峰式命名法又叫骆驼式命名法 xff0c 是编程时的一种命名规则 xff0c 指混合使用大小写字母来构成变量和函数的名字 意义 xff1a 多人做项目时 xff0c 若命名格式统一 xff0c 可以方便不同成员之间的代码交
  • 【逐函数详细讲解ORB_SLAM2算法和C++代码|System|1-24】

    包含所需库和其他类的头文件 定义命名空间ORB SLAM2 定义System类 它是整个ORB SLAM2算法的核心组件 它将各个子模块 如追踪 局部建图 回环检测等 组合在一起 并提供了处理单目 双目和RGB D图像的方法 System类
  • 【逐函数详细讲解ORB_SLAM2算法和C++代码|Tracking|1-25】

    在C 43 43 语法方面 xff0c 这段代码包括以下部分 xff1a 头文件包含 xff08 include xff09 xff1a 使用 include指令引入必要的头文件 xff0c 这些头文件提供了各种所需的类和函数定义 命名空间
  • 【逐函数详细讲解ORB_SLAM2算法和C++代码|Tracking|1-25】

    在Tracking类中 有一些成员变量和成员函数 下面是它们的简要概述 成员变量 System mpSystem 指向System类对象的指针 用于访问和操作ORB SLAM2系统 FrameDrawer mpFrameDrawer 指向F
  • 【逐函数详细讲解ORB_SLAM2算法和C++代码|Viewer|1-26】

    Viewer类的主要目的是实现ORB SLAM2算法的可视化部分 帮助用户更好地理解算法的运行过程和结果 为此 Viewer类与其他类 如System FrameDrawer MapDrawer和Tracking 协同工作 根据摄像机的帧率
  • #include<iostream>

    include lt iostream gt 是C 43 43 程序中非常常见的一条预处理指令 xff0c 它包含了iostream库 iostream库提供了C 43 43 程序中用于处理标准输入 输出流的基本功能 这个库中定义了一些重要
  • #include<algorithm>

    include lt algorithm gt 是C 43 43 中一个常用的预处理指令 xff0c 它包含了algorithm库 这个库提供了大量用于操作序列 xff08 例如数组 向量 列表等容器 xff09 的通用算法 xff0c 这
  • #include<fstream>

    include lt fstream gt 是C 43 43 程序中常用的预处理指令 xff0c 它包含了fstream库 这个库提供了用于处理文件输入 输出的类 fstream库主要包括以下几个类 xff1a std ifstream x
  • #include<chrono>

    include lt chrono gt 是C 43 43 标准库中用于处理时间和持续时间的头文件 chrono库提供了一系列用于表示时间点 时间段和时钟的类和函数 以下是chrono库中一些常用接口和用法 xff1a 持续时间 xff08
  • 【#include<opencv2/core/core.hpp>】

    include lt opencv2 core core hpp gt 是OpenCV库中的一个核心模块头文件 xff0c 它包含了许多用于处理图像和计算的基本数据结构 函数和类 以下是opencv2 core core hpp中的一些常用
  • 逐函数详细讲解ORB_SLAM2算法和C++语法|LoadImages|2-1

    完整可执行代码 https github com xiaoqiuslam orb2 视频讲解 逐函数讲解ORB SLAM2源码 xff5c 1 加载Euroc数据集图像 逐函数讲解ORB SLAM2源码 1 加载Euroc数据集图像 逐函数
  • Makefile介绍

    概述 什么是makefile xff1f 或许很多Windows的程序员都不知道这个东西 xff0c 因为那些Windows的集成开发环境 xff08 integrated development environment xff0c IDE
  • 逐函数详细讲解ORB_SLAM2算法和C++语法|System|2-2

    span class token comment Create SLAM system It initializes all system threads and gets ready to process frames span ORB
  • c_cpp_properties.json vscode ubuntu18.04

    在 Ubuntu 18 04 上使用 Visual Studio Code 时 xff0c 你可以根据以下示例配置 c cpp properties json 文件 假设你已经安装了 GCC 和 G 43 43 编译器 xff0c 这个示例
  • 激光SLAM 算法匹配原理

    文章目录 1 数据获取 xff1a 2 数据关联 xff1a 3 匹配 xff1a 4 位姿更新 xff1a 5 地图更新 xff1a 6 循环 xff1a 数据关联二维激光局部定位算法原理 激光SLAM xff08 Simultaneou

随机推荐