cocosCreator微信小游戏 之 登录流程(三)

2023-12-28 13:59

本文主要是介绍cocosCreator微信小游戏 之 登录流程(三),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

creator版本: 3.8.0

语言: TypeScript

环境: Mac


流程

微信小游戏在微信平台中运行,第一步操作就是登录。在登录之后才能:

  • 更方便的获取微信提供的用户身份标识
  • 更方便的验证数据传递的合法性

在微信平台中,登录的流程图大致如下:

Client Server 微信后台 wx.login获取code登录凭证 loop wx.request发送code auth.code2Session登录凭证校验 appId+appsecret+code 返回openId, session_key, unionId等 自定义登录态 保存openId,session_key等 loop 返回登录状态(成功、失败) wx.request发送业务请求 session_key加密算法 数据合法性 loop 返回业务数据 Client Server 微信后台

步骤:

  1. 客户端调用 wx.login 接口获取 临时登录凭证code(时效5分钟)
  2. 客户端调用 wx.request 接口将 code 发送给服务器
  3. 服务器调用 auth.code2Session 接口 通过请求参数 appId+appSecret+code 向微信后台请求
  4. 微信后台将 openId + session_key + unionId 反馈给服务器, 服务器可将这些数据进行存储
  5. 服务器可通过 auto.checkSessionKey 接口验证 session_key 的合法性
  6. 服务器告知客户端登录状态
  7. 登录成功状态下,客户端可通过wx.request向服务器请求其他数据
  8. 服务器通过session_key进行数据合法性验证或其他处理后,将数据返回给客户端

appId和appSecret


微信小程序的唯一的ID和唯一的密钥,在微信后台处,通过开发管理 -> 开发设置可获取
请添加图片描述

出于安全考虑:appId和AppSecret 都需要保密


auth.code2Session


该接口主要被服务器进行登录凭证校验。 返回的参数:

参数类型说明
openIdstring用户唯一标识符,业务逻辑请求需要
session_keystring密钥,服务器用于验证数据的合法性,客户端不需要
unionidstring用户在开放平台的唯一标识符
errcodenumber错误码,0表示成功
errmsgstring错误信息

errcode的类型主要有:

数值说明
-1系统繁忙,此时请开发者稍候再试
0请求成功
40029code无效
45011频率限制,每个用户每分钟100次
40226高风险等级用户,小程序登录拦截 。风险等级详见用户安全解方案

session_key字段主要在服务器中使用,以wx.getUserInfo为例,接口返回的字段:

  • rawData 不包括敏感信息的原始数据字符串,用于计算签名
  • signature 使用 sha1( rawData + sessionkey ) 得到字符串,用于校验用户信息
  • encryptedData 包括敏感数据在内的完整用户信息的加密数据
  • iv 加密算法的初始向量

客户端可以将 rawDatasignature 字段发送给服务器,然后服务器通过相同的算法加密,获取新的 signature, 两者比对,就可以检验数据的合法性了。

示例:


因能力限制,最后粘贴下客户端的逻辑实现相关:

  • cocosCreator的登录页面,增加登录按钮
  • 脚本中逻辑处理,实现:
public clickLogin(callBack?: any) {const wx = window['wx'];let object: any = {timeout: 10000,         // 超时时间毫秒success: (res) => {// 用户登录凭证,有效期5分钟let code = res.code;        console.log("登录获取凭证成功, code:", code);if (callBack) {callBack(code);}},fail: (err) => {console.log(`wx.login 失败, errorCode:${err.errno}, msg:${err.errMsg}`)},};wx.login(object);
}

更多内容参考:微信小游戏-登录态管理

最后,祝大家学习生活愉快!

这篇关于cocosCreator微信小游戏 之 登录流程(三)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/546189

相关文章

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

Spring Boot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)

《SpringBoot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)》本文将以一个实际案例(用户管理系统)为例,详细解析SpringBoot中Co... 目录引言:为什么学习Spring Boot分层架构?第一部分:Spring Boot的整体架构1.1

nodejs打包作为公共包使用的完整流程

《nodejs打包作为公共包使用的完整流程》在Node.js项目中,打包和部署是发布应用的关键步骤,:本文主要介绍nodejs打包作为公共包使用的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言一、前置准备二、创建与编码三、一键构建四、本地“白嫖”测试(可选)五、发布公共包六、常见踩坑提醒

Ubuntu向多台主机批量传输文件的流程步骤

《Ubuntu向多台主机批量传输文件的流程步骤》:本文主要介绍在Ubuntu中批量传输文件到多台主机的方法,需确保主机互通、用户名密码统一及端口开放,通过安装sshpass工具,准备包含目标主机信... 目录Ubuntu 向多台主机批量传输文件1.安装 sshpass2.准备主机列表文件3.创建一个批处理脚

90%的人第一步就错了! 顺利登录wifi路由器后台的技巧

《90%的人第一步就错了!顺利登录wifi路由器后台的技巧》登录Wi-Fi路由器,其实就是进入它的后台管理页面,很多朋友不知道该怎么进入路由器后台设置,感兴趣的朋友可以花3分钟了解一下... 你是不是也遇到过这种情况:家里网速突然变慢、想改WiFi密码却不知道从哪进路由器、新装宽带后完全不知道怎么设置?别慌

一个Java的main方法在JVM中的执行流程示例详解

《一个Java的main方法在JVM中的执行流程示例详解》main方法是Java程序的入口点,程序从这里开始执行,:本文主要介绍一个Java的main方法在JVM中执行流程的相关资料,文中通过代码... 目录第一阶段:加载 (Loading)第二阶段:链接 (Linking)第三阶段:初始化 (Initia

Git打标签从本地创建到远端推送的详细流程

《Git打标签从本地创建到远端推送的详细流程》在软件开发中,Git标签(Tag)是为发布版本、标记里程碑量身定制的“快照锚点”,它能永久记录项目历史中的关键节点,然而,仅创建本地标签往往不够,如何将其... 目录一、标签的两种“形态”二、本地创建与查看1. 打附注标http://www.chinasem.cn

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom