cocos + KBEngine 微信小游戏 - 兼容wss通讯方式

2024-01-21 08:48

本文主要是介绍cocos + KBEngine 微信小游戏 - 兼容wss通讯方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

微信小游戏的域名只支持 https (wx.request、wx.uploadFile、wx.downloadFile) 和 wss (wx.connectSocket) 协议;所以我们的服务器打算使用nginx反向代理https/wss。

准备

准备好域名,并且经过ICP备案

配置管理后台

在小游戏后台设置服务器的socket合法域名,把我们与服务器通讯的地址加进去
注意:域名必须经过 ICP 备案;

配置服务器

1.首先申请Https证书,阿里云有免费的可以先购买使用(域名类型:单域名; 证书类型:dv ssl; 加密等级:免费版)
2.拿到证书后绑定我们之前准备好的域名
3.选择nginx证书下载,可以对证书重命名后准备使用
4.服务器安装nginx
5.打开nginx的配置文件 nginx.conf,找到443所在的server块进行配置

	# 新增login_addr块upstream login_addr {server 127.0.0.1:20013 weight=1;}server {listen       443 ssl http2 default_server;listen       [::]:443 ssl http2 default_server;server_name  xxxx;     # 这里配置你的域名root         /usr/share/nginx/html;# 把你下载的证书上传到服务器,并且指定路径ssl_certificate "/etc/nginx/ssl/server.crt";		# 根据你的证书路径设置ssl_certificate_key "/etc/nginx/ssl/server.key";	# 根据你的证书路径设置ssl_session_cache shared:SSL:1m;ssl_session_timeout  10m;ssl_ciphers HIGH:!aNULL:!MD5;ssl_prefer_server_ciphers on;# Load configuration files for the default server block.include /etc/nginx/default.d/*.conf;location / {}error_page 404 /404.html;location = /40x.html {}error_page 500 502 503 504 /50x.html;location = /50x.html {}# 设计思想:nginx对我们来说只是一个转发的功能,但为了对登录做一个负载均衡,# 所以决定把与login的通讯和base的通讯区分开,给出的方案是修改客户端登录的连接信息# 通过请求信息来决定如何转发# 服务器对应的配置就有了下面俩个块 /loginapp 和 /baseapplocation /loginapp {# 指定我们上面定义的地址,摘出来的目的是为了负载均衡proxy_pass http://login_addr;proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection "Upgrade";}# 由于KBEngine的baseapp本身就是负载均衡的,所以对baseapp,主需要原样转发即可# 我目前只使用了一台机器,所以这里转发的地址是 127.0.0.1location /baseapp {proxy_pass http://127.0.0.1:$arg_port;proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection "Upgrade";}}

6.重启nginx

客户端适配

1.修改客户端js插件

	// 修改 getServerAddr 函数// 修改的结果是如果不启动wss连接,地址保持不变// 如果启动wss连接,连接请求地址将被改成下面形式// wss://域名/loginapp?port=20013// wss://域名/baseapp?port=20013 // 也就是我们设置nginx时新增的那俩个块形式this.getServerAddr = function(ip, port, app){var serverAddr = KBEngine.app.protocol + ip;if(KBEngine.app.isWss) {serverAddr += '/'+ app + '?port=' + port;}else if(port != ""){serverAddr += ":" + port;}return serverAddr;}// 接下来修改 getServerAddr 调用的地方,添加第三个参数// 该参数使用 KBEngine.app.currconnect将要被赋值的值// 示例如下:this.login_loginapp = function(noconnect){  if(noconnect){var serverAddr = this.getServerAddr(KBEngine.app.ip, KBEngine.app.port, "loginapp");KBEngine.INFO_MSG("KBEngineApp::login_loginapp: start connect to " + serverAddr + "!");KBEngine.app.currconnect = "loginapp";	}}

2.客户端在初始化KBEngine时 设置使用wss连接

启动服务器,客户端连接测试!

这篇关于cocos + KBEngine 微信小游戏 - 兼容wss通讯方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Spring创建Bean的八种主要方式详解

《Spring创建Bean的八种主要方式详解》Spring(尤其是SpringBoot)提供了多种方式来让容器创建和管理Bean,@Component、@Configuration+@Bean、@En... 目录引言一、Spring 创建 Bean 的 8 种主要方式1. @Component 及其衍生注解

python中的显式声明类型参数使用方式

《python中的显式声明类型参数使用方式》文章探讨了Python3.10+版本中类型注解的使用,指出FastAPI官方示例强调显式声明参数类型,通过|操作符替代Union/Optional,可提升代... 目录背景python函数显式声明的类型汇总基本类型集合类型Optional and Union(py

Linux系统管理与进程任务管理方式

《Linux系统管理与进程任务管理方式》本文系统讲解Linux管理核心技能,涵盖引导流程、服务控制(Systemd与GRUB2)、进程管理(前台/后台运行、工具使用)、计划任务(at/cron)及常用... 目录引言一、linux系统引导过程与服务控制1.1 系统引导的五个关键阶段1.2 GRUB2的进化优

IDEA与MyEclipse代码量统计方式

《IDEA与MyEclipse代码量统计方式》文章介绍在项目中不安装第三方工具统计代码行数的方法,分别说明MyEclipse通过正则搜索(排除空行和注释)及IDEA使用Statistic插件或调整搜索... 目录项目场景MyEclipse代码量统计IDEA代码量统计总结项目场景在项目中,有时候我们需要统计

C#和Unity中的中介者模式使用方式

《C#和Unity中的中介者模式使用方式》中介者模式通过中介者封装对象交互,降低耦合度,集中控制逻辑,适用于复杂系统组件交互场景,C#中可用事件、委托或MediatR实现,提升可维护性与灵活性... 目录C#中的中介者模式详解一、中介者模式的基本概念1. 定义2. 组成要素3. 模式结构二、中介者模式的特点

详解Java中三种状态机实现方式来优雅消灭 if-else 嵌套

《详解Java中三种状态机实现方式来优雅消灭if-else嵌套》这篇文章主要为大家详细介绍了Java中三种状态机实现方式从而优雅消灭if-else嵌套,文中的示例代码讲解详细,感兴趣的小伙伴可以跟... 目录1. 前言2. 复现传统if-else实现的业务场景问题3. 用状态机模式改造3.1 定义状态接口3