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 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> websocket数据处理 -> 正文阅读

[网络协议]websocket数据处理

最近用websocket和后端通信发送数据和接收到数据的处理打算记录下,需求是前端先通过websocket向后端发送要接收数据的设备ID后端收到后返回ID对应的数据

let lockReconnect=false;//避免重复连接
let ip=location.host+'alarmNotify';
let wsUrl="wss://"+ip;
let ws;
let tt;
let latAadLngData;
let devArr = [];//存放传入后端ID的数组
 creatMenus()

    function creatMenus(definDataId) {
        controller.getDevInfo((res) => {
            latAadLngData = res;
            for (let i = 0; i < latAadLngData.length; i++) {
                devArr.push(latAadLngData[i].devId);//获取数组ID
                lis += "<li data-devId=" + latAadLngData[i].devId + " class='detail' id='details" + i +
                    "'><button value=\"" + latAadLngData[i].lat + ',' +
                    latAadLngData[i].lng + ',' + latAadLngData[i].deptName + ',' + latAadLngData[i]
                    .streamAddr + ',' +
                    "\" style='margin:6px 0px;height:36px; width: 300px;display: block;' οnclick='position(this)'>" +
                    latAadLngData[i].devName + "</button></li>"
            }
            $('#latlngContainer').html(lis)
        })
    }
function createWebSocket(wsUrl){
    try{
        ws=new WebSocket(wsUrl);
        init()
     }catch(e){
        reconnect(wsUrl);
     }
}
function init(){
ws.onclose=function(){
console.log('连接关闭')
};
ws.onerror=function(){
console.log('发生异常')
};
ws.onopen=function(){
consloe.log('连接成功')
 let data = JSON.stringify({
                "content": {},
                "devIDs": devArr,
                "msgTime": 1644912412517,
                "msgType": 4,
                "msgUUID": "0d646108-d0a6-4a3b-b595-52324bf0f98c"
            })
            ws.send(data)//向后端发送设备ID数据
};
ws.onmessage=function(event){
 let serverData = JSON.parse(event.data)//接收到后端返回数据处理
}
}
function handleMessage(serverData){
 let definDatas = Object.keys(serverData.content);//拿到后端返回的ID值可能是数组
   let serveType = serverData.msgType;
    if (serveType == '4') {
            const lis = document.getElementsByClassName('detail')//获取列表元素
            for (let i = 0; i < lis.length; i++) {   //循环遍历获取到的元素
                if (definDatas.indexOf($(lis[i]).attr('data-devId')) > -1) {   //判断拿到的数据是否和元素的ID相匹配
                    $(lis[i]).addClass('alarmClass')   //如果匹配就添加一个元素类名
                    let elm = document.getElementsByName('alarmClass');
                } else {
                    $(lis[i]).removeClass('alarmClass')
                }
            }
        }
}
function reconnect(url){
if(lockReconnect){
return;
}
lockReconnect = true;
        tt && clearTimeout(tt);
        tt = setTimeout(function () {
            createWebSocket(url);
            lockReconnect = false;
        }, 5000)
}
  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-03-04 15:57:23  更:2022-03-04 15:59:19 
 
开发: 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年10日历 -2024/10/5 13:24:49-

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