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

相关文章

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

Java发送SNMP至交换机获取交换机状态实现方式

《Java发送SNMP至交换机获取交换机状态实现方式》文章介绍使用SNMP4J库(2.7.0)通过RCF1213-MIB协议获取交换机单/多路状态,需开启SNMP支持,重点对比SNMPv1、v2c、v... 目录交换机协议SNMP库获取交换机单路状态获取交换机多路状态总结交换机协议这里使用的交换机协议为常

k8s admin用户生成token方式

《k8sadmin用户生成token方式》用户使用Kubernetes1.28创建admin命名空间并部署,通过ClusterRoleBinding为jenkins用户授权集群级权限,生成并获取其t... 目录k8s admin用户生成token创建一个admin的命名空间查看k8s namespace 的

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

Pandas处理缺失数据的方式汇总

《Pandas处理缺失数据的方式汇总》许多教程中的数据与现实世界中的数据有很大不同,现实世界中的数据很少是干净且同质的,本文我们将讨论处理缺失数据的一些常规注意事项,了解Pandas如何表示缺失数据,... 目录缺失数据约定的权衡Pandas 中的缺失数据None 作为哨兵值NaN:缺失的数值数据Panda

java读取excel文件为base64实现方式

《java读取excel文件为base64实现方式》文章介绍使用ApachePOI和EasyExcel处理Excel文件并转换为Base64的方法,强调EasyExcel适合大文件且内存占用低,需注意... 目录使用 Apache POI 读取 Excel 并转换为 Base64使用 EasyExcel 处

Spring Boot中获取IOC容器的多种方式

《SpringBoot中获取IOC容器的多种方式》本文主要介绍了SpringBoot中获取IOC容器的多种方式,包括直接注入、实现ApplicationContextAware接口、通过Spring... 目录1. 直接注入ApplicationContext2. 实现ApplicationContextA

linux查找java项目日志查找报错信息方式

《linux查找java项目日志查找报错信息方式》日志查找定位步骤:进入项目,用tail-f实时跟踪日志,tail-n1000查看末尾1000行,grep搜索关键词或时间,vim内精准查找并高亮定位,... 目录日志查找定位在当前文件里找到报错消息总结日志查找定位1.cd 进入项目2.正常日志 和错误日