IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> uniapp使用websocket,后端使用thinkphp5.1和workerman -> 正文阅读

[网络协议]uniapp使用websocket,后端使用thinkphp5.1和workerman

1. 基于ThinkPHP5.1框架,使用TP官方手册上的扩展库:

composer require topthink/think-worker=2.0.*

?安装完之后,找到目录vendor/topthink/think-worker ,里面就是开启worker服务的指令的代码

2. 执行php think worker:gateway出现GatewayWorker Not Support On Windows.

解决方案:https://blog.csdn.net/weixin_44423832/article/details/104463478

3. 接下来,使用uniapp的websocket的注意事项:

?其中需要注意一点:uni.onSocketOpen这个函数只能调用一次,不能出现多个,只有一个会生效

页面初始化 需要发送消息 需要在uni.onSocketOpen 中使用 uni.sendSocketMessage

之后,如果想要发送消息,只需要调用uni.sendSocketMessage即可

data(){
    return {
        isSocketClose:false,    // 是否关闭socket
        reconnectCount:5,       // 重连次数
        connectIndex:1,			//第几次连接websocket 不超过reconnectCount的数字
        heartbeatInterval:"",   // 心跳定时器
        isStart:false,          // 是否启动设备
        pingInterval:5000,		//定时发送心跳包 '{"type":"pong"}'
        pingData:{"type":"pong"},			//心跳包数据
    }
}

methods{
    //连接websocket
			connectWebsocket(){
				let that = this;
				uni.connectSocket({
				  url: that.websocket_url,//websocket的链接
				  success:function(res){
					//连接成功
					// that.connectIndex = 1;
					console.log("调用connectSocket接口成功,正在尝试连接webSocket:"+JSON.stringify(res));
				  },
				  fail:function(res){
					  //这里的失败 不会触发 --
					  console.log("调用connectSocket接口失败:"+JSON.stringify(res));
				  }
				});
				
				//打开websocket连接
				uni.onSocketOpen(function (res) {
					console.log("连接webSocket成功,正在尝试发送消息:"+JSON.stringify(res));
					//定时连接-发送心跳包
					that.sendPingData();
					//发送登录消息--每次连接都要发送登录消息
					that.sendLoginMsg();
				});
				
				//连接断开检测
				uni.onSocketError(function (res) {
					  console.log('WebSocket连接打开失败,请检查!');
						//停止发送心跳
					  clearInterval(that.heartbeatInterval)
						//如果不是人为关闭的话,进行重连
					  if(!that.isSocketClose){
						that.reconnect()
					  }
				});
				 // 监听连接关闭
				uni.onSocketClose(function (e) {
					console.log('WebSocket连接关闭!');
					clearInterval(that.heartbeatInterval)
					if(!that.isSocketClose){
						that.reconnect()
					}
				});
				//接收websocket消息
				uni.onSocketMessage(function (res) {
					let msg = JSON.parse(res.data);
					console.log("接收websocket消息:",msg);
					that.screenMsg(msg);
				});
				
			},
			//重连websocket
			reconnect(){
				let that = this;
				//重连,先结束心跳;
				clearInterval(that.heartbeatInterval);
				//断线后重连几次
				if(that.connectIndex <= that.reconnectCount){
					console.log("这是第"+that.connectIndex+"次重连...");
					that.connectIndex++;
					that.connectWebsocket();
				}else{
					console.log("已达到最大重连数:"+that.reconnectCount+",不再进行重连!");
				}
			},
			//开启定时器
			sendPingData(){
				let that = this;
				that.sendWebSocket({'msg':'这是定时器'},1);
			},
			//发送登录消息
			sendLoginMsg(){
				let that = this;
				var nowDate = new Date();
				let content = {text:that.user_info.nickname+"已登录"};
				let msg = {type:'login',room_id:that.room_id,msg:{view_index:0,time:nowDate.getHours()+":"+nowDate.getMinutes(),type:'text',userinfo:that.user_info,content:content}}
				that.sendWebSocket(msg);
			},
			//触发发送websocket
			/**
			 * @param {Object} msg 发送的内容
			 * @param {Object} type 是否调用定时心跳 -- 一个页面只能使用一个onSocketOpen
			 */
			sendWebSocket(msg,type){
				let that = this;
				// console.log(msg);
					switch(type){
						case 1:
							clearInterval(that.heartbeatInterval)
							// 5秒发送一次心跳
							that.heartbeatInterval = setInterval(()=>{
								console.log("定时器:"+that.pingInterval);
								uni.sendSocketMessage({
								  data: JSON.stringify(that.pingData),
								  success:function(res){
									console.log("发送websocket定时心跳包成功:"+JSON.stringify(res));
								  },
								  fail:function(res){
									console.log("发送websocket定时心跳包失败:"+JSON.stringify(res));
								  }
								});
							},that.pingInterval)
							break;
						case 0:
						default:
							uni.sendSocketMessage({
							  data: JSON.stringify(msg),
							  success:function(res){
								console.log("发送websocket消息成功:",msg);
							  },
							  fail:function(res){
								console.log("发送websocket消息失败:",msg);
							  },
							  complete:function(res){
								  console.log("发送websocket操作完成:",msg);
							  }
							});
							break;
					}
			
			},
}

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2021-08-20 15:27:26  更:2021-08-20 15:28:14 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 20:25:47-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码