Think-Swoole之WebSocket客户端消息解析与使用SocketIO处理用户UID与fd关联

Think-Swoole之WebSocket客户端消息解析与使用SocketIO处理用户UID与fd关联

WebSocket 客户端消息的解析

前面我们演示了当客户端连接服务端,会触发连接事件,事件中我们要求返回当前客户端的 fd。当客户端发送消息给服务端,服务端会根据我们的规则将消息发送给指定 fd 的客户端:

app/listener/WsConnect.php

 emit('sendfd',$ws -> getSender());    }}

app/listener/WsTest.php

 to(intval($event['to'])) -> emit('testcallback',$event['message']);    }}

客户端执行上述两个事件后,控制台打印出以下信息:

3e65bb5742e35710db2e3ae1e9bba30.png

返回信息前面有一些数字,40、42都代表什么意义呢?

因为我们使用的扩展是基于 SocketIO 协议的,这些数字可以理解为协议的代号。

打开 /vendor/topthink/think-swoole/src/websocket/socketio/Packet.php ,有以下内容:

ac3e617f79cdf6b208b304f2ca64911.png

上面是 Socket 类型,下面是引擎,前后两个代号上下拼凑得到:

40:”MESSAGE CONNECT”42:”MESSAGE EVENT”

结合这些代码,能知道 SocketIO 中消息的大体运作情况。

通过控制台打印出的消息,我们发现这些消息不能直接拿到使用,需要进行截取处理:

test.html

        Document消息:接收者:    var ws = new WebSocket("ws://127.0.0.1:9501/");    ws.onopen = function(){        console.log('连接成功');    }    //数据返回的解析    function mycallback(data){        var start = data.indexOf('[') // 第一次出现的位置        var start1 = data.indexOf('{')        if(start = 0 && start1 >= 0){            start = Math.min(start,start1);        }        if(start >= 0){            console.log(data);            var json = data.substr(start); //截取            var json = JSON.parse(json);            console.log(json);        }    }    ws.onmessage = function(data){        // console.log(data.data);        mycallback(data.data);    }    ws.onclose = function(){        console.log('连接断开');    }    function send(){        var message = document.getElementById('message').value;        var to = document.getElementById('to').value;        console.log("准备给" + to + "发送数据:" + message);        ws.send(JSON.stringify(['test',{            to:to,            message:message        }])); //发送的数据必须是 ['test',数据] 这种格式    }

解析后的数据:

d049d27768d703d197019f59ceac116.png

使用 SocketIO 处理消息业务

SocketIO 的相关知识可以查看文档,重点看客户端方面知识:

https://www.w3cschool.cn/socket/socket-k49j2eia.html

iotest.html

        Document消息:接收者:    //http 协议    var socket = io("http://127.0.0.1:9501", {transports: ['websocket']});    socket.on('connect', function(){        console.log('connect success');    });    socket.on('close',function(){       console.log('connect close')    });    //send_fd 为自定义的场景值,和后端对应    socket.on("sendfd", function (data) {        console.log(data)    });    //testcallback 为自定义的场景值,和后端对应    socket.on("testcallback", function (data) {        console.log(data)    });    function send() {        var message = document.getElementById('message').value;        var to = document.getElementById('to').value;        socket.emit('test', {            //属性可自行添加            to:to,            message:message        })    }

var socket = io(“http://127.0.0.1:9501”, {transports: [‘websocket’]}); 中第二个参数指明要升级的协议。

JoinMC智能客服 JoinMC智能客服

JoinMC智能客服,帮您熬夜加班,7X24小时全天候智能回复用户消息,自动维护媒体主页,全平台渠道集成管理,电商物流平台一键绑定,让您出海轻松无忧!

JoinMC智能客服 23 查看详情 JoinMC智能客服

app/listener/WsConnect.php

 emit('sendfd',$ws -> getSender());    }}

app/listener/WsTest.php

 to(intval($event['to'])) -> emit('testcallback',$event['message']);        $ws -> to(intval($event['to'])) -> emit('testcallback',[            'form' => [                'id' => 10,                'fd' => $ws -> getSender(),                'nickname' => '张三'            ],            'to' => [                'id' => 11,                'fd' => intval($event['to']),                'nickname' => '李四'            ],            'massage' => [                'id' => 888,                'create_time' => '2020-03-13',                'content' => $event['message']            ]        ]);    }}

开启两个客户端,fd 分别是5、6:

a15a44c4dc464e480664ac7add1efb2.png

WsConnect.php 中,有 $ws -> emit(‘sendfd’,$ws -> getSender()); 发送 fd 消息对应的场景值是 “sendfd” ,在 iotest.html 中,有socket.on(“sendfd”, function (data) {console.log(data)}); 这段代码,其中也有场景值 “sendfd”,这行代码可以直接获取对应场景值的信息,所以控制台上会打印出 fd 值。

用 fd 5 向 fd 6 发送信息:

73542665974ef733eb1a7afd192a7f5.png

两个客户端均会受到信息:

1752f5ebc05df83efbe7fc07a0c55f8.png

可见消息已经经过解析,因为 WsTest.php 中 发送消息指定场景值 testcallback,iotest.html 中通过 socket.on(“testcallback”, function (data){console.log(data)}); 可直接获取解析过的结果。

这就看出了 SocketIO 在客户端消息接收方面的便捷之处了。

用户 UID 和客户端 fd 的绑定

前面的例子中,都是通过指定 fd 来向客户端发送消息,实际场景中,我们不可能通过 fd 确定发送对象,因为 fd 不是固定不变的,因此需要将用户的 UID 与客户端的 fd 进行绑定,进而可以通过选择用户,来确定 fd 完成消息的发送。

只需要将前端页面的 HTTP 连接中增加 UID 参数即可:

test.html

var ws = new WebSocket("ws://127.0.0.1:9501/?uid=1");

iotest.html

var socket = io("http://127.0.0.1:9501?uid=1", {transports: ['websocket']});

后端可以在连接事件中进行绑定:

app/listener/WsConnect.php

 get('uid');        //获取 fd        $fd = $ws -> getSender();        //获取到 uid 和 fd 后,可以存数据库,内存或者 redis        $ws -> emit('sendfd',[            'uid' => $uid,            'fd' => $fd        ]);    }}

有了 UID 与 fd ,可以在每次连接成功后,更新数据库,连接断开后再清空用户对因的 fd。假如服务器重启,那么二者的对应关系也就没用了,所以不必存入数据库,存入 Redis 最好,通过 Redis 的 Hash 来映射二者关系也是不错的选择。

以上就是Think-Swoole之WebSocket客户端消息解析与使用SocketIO处理用户UID与fd关联的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/351729.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
在CentOS上如何使用PyTorch进行模型训练
上一篇 2025年11月5日 22:35:54
win10家庭版怎么开组策略_win10家庭版开启组策略功能教程
下一篇 2025年11月5日 22:36:00

相关推荐

  • WebSocket心跳检测与断线重连示例

    WebSocket通过心跳检测与断线重连机制提升连接稳定性,客户端每30秒发送ping,服务端回应pong,超时未响应则判定断线;onclose触发后按指数退避策略重试连接,最多5次,确保网络波动后可靠恢复。 WebSocket在长时间通信中容易因网络波动或服务端超时导致连接中断。为了确保连接稳定,…

    2026年5月10日
    000
  • WebSocket消息队列处理性能优化

    优化WebSocket性能需解耦通信与业务逻辑,通过消息队列异步处理、二进制序列化、数据压缩、批量发送及动态心跳机制,提升吞吐量并降低延迟。 处理WebSocket消息时,性能瓶颈常出现在消息的接收、处理和分发环节。优化核心在于解耦通信与业务逻辑,并高效管理消息流。 引入消息队列进行异步解耦 直接在…

    2026年5月10日
    000
  • 实时加密深度分析平台盘点?3款开源数据源

    CryptoWatch开源接口提供高频更新的全球交易所深度数据,支持多语言调用与可视化渲染;2. TradingView开源脚本集成Pine Script模板,可自定义订单簿深度分析并设置买卖压力警报;3. OpenBB Terminal支持本地部署,结合命令行拉取加密资产深度数据,实现技术指标叠加…

    2026年5月10日
    000
  • 怎样使用 JavaScript 的 Typed Arrays 处理二进制数据?

    Typed Arrays通过ArrayBuffer实现对二进制数据的高效操作,需用视图如Int32Array或DataView访问,支持多种数据类型和字节序控制,适用于处理图像、音频等原始数据。 JavaScript 的 Typed Arrays 提供了一种高效处理二进制数据的方式,特别适用于操作原…

    2026年5月10日
    100
  • 怎样使用javascriptArrayBuffer_二进制数据如何操作?

    ArrayBuffer 是 JavaScript 中操作二进制数据的基础内存容器,需配合 Uint8Array、Int32Array 或 DataView 等视图使用;其长度固定,创建后不可变,常用于文件读取、网络请求、Canvas 像素处理及 WebAssembly 等场景。 JavaScript…

    2026年5月10日
    000
  • 无数据库实现简易多人协作应用:可行性与技术方案

    本文探讨了在没有传统后端数据库的情况下,实现一个简单的多人协作列表应用的可行性。针对少量用户、小数据量的场景,介绍了利用浏览器本地存储和实时通信技术(如WebSocket或Firebase Realtime Database)实现数据同步和更新的方法,并分析了其优缺点和适用场景。 在某些特定场景下,…

    2026年5月10日
    000
  • html5能否插入带表单的文档_html5表单文档嵌入与数据提交【步骤】

    HTML5中无法直接嵌入外部带表单的HTML文档并原生提交;可行方案有四:一、用iframe嵌入,需同源或CORS支持,并用postMessage通信;二、用fetch+DOMParser动态加载表单片段并手动绑定事件;三、在当前页面直接编写表单,最规范且兼容性好;四、用JavaScript+fet…

    2025年12月23日
    500
  • html5如何推送数据_html5数据推送实现方法【接口实现】

    HTML5提供四种实时数据推送机制:一、SSE实现单向服务器推送;二、WebSocket支持双向低延迟通信;三、轮询模拟推送兼容旧环境;四、Broadcast Channel实现同源页面间广播。 如果您的Web应用需要实时接收服务器端发送的数据,HTML5提供了多种原生机制来实现数据推送。以下是几种…

    2025年12月23日
    000
  • 如何开发html5_HTML5应用开发入门指南【入门】

    HTML5应用开发入门需按五步进行:一、搭建标准文档结构,含DOCTYPE声明、html根元素及meta标签;二、使用header、nav、main等语义化标签组织内容;三、嵌入video、audio、canvas并绑定交互事件;四、通过Service Worker实现离线缓存;五、用特性检测替代U…

    2025年12月23日
    000
  • html5如何转换数据_html5数据转换方法详解【数据处理】

    HTML5中数据转换主要通过五种方法:一、JavaScript内置方法(parseInt、parseFloat、+运算符)转换字符串与数字;二、JSON.stringify/parse实现结构化数据序列化;三、DataView和TypedArray处理二进制数据;四、表单valueAsNumber/…

    2025年12月23日
    000
  • 设置使用html5模式_文档类型声明与特性检测【技巧】

    需声明并用Modernizr、原生JS或@supports检测特性。一、首行写;二、引入Modernizr检测HTML5/CSS3特性;三、手动检测localStorage、Canvas、Fetch;四、用@supports做CSS特性判断。 如果您在编写网页时希望确保浏览器以最新的HTML5标准解…

    2025年12月23日
    000
  • Flask 应用中实现动态图片显示与定时刷新:从基础到文件上传

    Flask 应用中实现动态图片显示与定时刷新:从基础到文件上传Flask 应用中实现动态图片显示与定时刷新:从基础到文件上传Flask 应用中实现动态图片显示与定时刷新:从基础到文件上传Flask 应用中实现动态图片显示与定时刷新:从基础到文件上传

    本教程将指导您如何在flask应用中高效地显示和管理图片,特别关注于如何利用javascript实现图片内容的定时刷新,以及如何通过服务器端文件上传机制来更新图片。文章涵盖flask静态文件服务、客户端刷新策略、文件上传处理及相关最佳实践,旨在提供一个完整的动态图片解决方案。 在现代Web应用中,动…

    2025年12月23日 用户投稿
    600
  • 网站内嵌消息系统实现指南:利用表单服务简化用户通信

    本教程探讨了在网站中集成简易消息系统的可行方案,特别针对小规模用户群体的站内通信需求。鉴于直接嵌入完整电子邮件客户端的复杂性与局限性,文章推荐采用基于表单提交的第三方服务(如Formspree)实现用户与管理员之间的邮件通知。该方法无需复杂的后端开发,即可快速搭建起高效、安全的站内信息传递渠道。 引…

    2025年12月23日
    000
  • python五子棋的html怎么运行_运行python五子棋html文件方法【教程】

    首先确认五子棋HTML文件是否包含完整前端逻辑,检查文件结构及外部资源引用;若仅为静态页面则无法运行交互功能。其次尝试双击直接打开HTML文件,若显示空白则通过浏览器开发者工具查看报错。对于依赖同源策略的资源,需使用Python启动本地服务器,在终端执行python -m http.server 8…

    2025年12月23日
    000
  • 在Flask应用中利用JavaScript实现动态图片更新教程

    在Flask应用中利用JavaScript实现动态图片更新教程在Flask应用中利用JavaScript实现动态图片更新教程在Flask应用中利用JavaScript实现动态图片更新教程在Flask应用中利用JavaScript实现动态图片更新教程

    本教程详细介绍了如何在python flask web应用中实现图片的周期性自动更新。我们将学习如何使用javascript在客户端定时刷新图片,并探讨flask后端如何配合处理图片文件,确保前端能够获取到最新的图像内容,即使文件名保持不变。 引言:动态图片更新的需求 在现代Web应用开发中,许多场…

    2025年12月23日 用户投稿
    000
  • 在React应用中实施内容安全策略(CSP)及处理内联样式与脚本冲突

    本教程旨在指导开发者如何在react应用中有效实施内容安全策略(csp),特别针对`create-react-app`等构建工具可能产生的内联样式和脚本与csp指令冲突的问题。文章将详细阐述csp的基本原理,分析常见冲突原因,并提供包括使用哈希、nonce以及重构代码等多种解决方案,以确保应用安全且…

    2025年12月23日
    100
  • Opera DevTools热重载,HTML改CSS页面瞬变!

    Opera DevTools 热重载功能可在保存 HTML 或 CSS 文件时实时更新页面样式,提升开发效率。首先需在 DevTools 设置中启用“自动重载”,随后通过本地服务器(如 npx http-server)运行项目以支持文件监听。配合 VS Code 等编辑器的 Live Server …

    2025年12月23日
    000
  • 如何将Python后端逻辑与Django和HTML进行集成

    本教程旨在指导初学者如何将独立的Python命令行应用程序转换为基于Django的Web应用。文章将详细阐述如何通过Django的视图、URL配置和表单系统,将Python逻辑与HTML前端进行交互,实现用户输入捕获和结果展示。重点在于重构Python代码以适应Web环境,并利用Django For…

    2025年12月23日
    000
  • JavaScript中如何通过按钮控制函数内循环的启停

    本文详细阐述了在JavaScript中,如何利用控制标志和递归`setTimeout`模式,实现通过按钮精确控制函数内部循环的启动与停止,尤其适用于需要延迟执行的场景。通过清晰的代码示例和专业讲解,帮助开发者掌握响应式循环控制的实现方法。 在前端开发中,我们经常会遇到需要在后台执行一系列重复操作,并…

    2025年12月23日
    000
  • 将独立的Python逻辑集成到Django Web应用:构建一个交互式计时器

    本教程详细介绍了如何将独立的Python命令行应用程序(如计时器)迁移并集成到Django Web框架中。文章将指导读者理解从命令行交互到Web界面交互的转变,重点讲解如何利用Django的视图、模板和表单功能来接收用户输入、处理后端逻辑,并最终在Web环境中展示结果。同时,也将探讨在Web应用中处…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信