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)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月5日 22:35:36
下一篇 2025年11月5日 22:40:11

相关推荐

  • 探索加密货币市场的高频交易策略

    探索加密货币市场的高频交易策略,无疑是当下金融科技领域最令人振奋的话题之一。在这个24/7不间断运作的数字资产世界里,速度与效率成为了决定成败的关键。高频交易(hft)并非仅仅是快速买卖那么简单,它是一门集成了先进算法、复杂数学模型和尖端技术的艺术,旨在利用市场中稍纵即逝的微小机会。从市场微结构的不…

    好文分享 2025年12月11日
    000
  • PHP如何与WebSocket服务器交互_PHP WebSocket客户端通信实践

    PHP可通过Textalk/websocket库与WebSocket服务器交互,实现双向实时通信。首先使用Composer安装库,编写客户端代码连接ws://localhost:8080,调用send()发送消息,receive()接收消息,并用close()关闭连接。需注意服务器地址、端口、防火墙…

    2025年12月11日
    000
  • Laravel WebSockets 安装问题解决指南

    本文旨在帮助开发者解决在 Laravel 项目中安装 beyondcode/laravel-websockets 包时遇到的依赖冲突问题。通过移除 composer.lock 文件并重新安装依赖,可以有效解决版本不兼容导致的安装失败,确保 WebSocket 功能的顺利集成。 在 Laravel 项…

    2025年12月11日
    000
  • Bitfinex:专业交易

    在加密货币交易的浩瀚宇宙中,bitfinex无疑是其中一颗耀眼的星辰。它不仅仅是一个简单的交易所,更是一个为专业交易者量身定制的复杂生态系统。踏入bitfinex的大门,你将发现一个集高流动性、先进交易工具、深度市场数据以及强大安全保障于一体的交易殿堂。这里汇聚了全球顶级的机构投资者、资深交易员以及…

    好文分享 2025年12月10日
    000
  • php如何防止跨站脚本攻击(XSS)?PHP XSS攻击防御策略

    <blockquote>答案:防止XSS最核心的是上下文敏感的输出转义。需结合htmlspecialchars、json_encode等函数对HTML、JavaScript、CSS等不同上下文进行安全转义,同时辅以输入验证和CSP策略,确保用户输入在输出时不会被浏览器误解析为可执行代码。…

    好文分享 2025年12月10日
    000
  • PHP与数据库时间戳比较:实现高效数据检索与通知

    本教程旨在解决PHP中日期(如date(“Y-m-d”))与数据库中完整时间戳(如DATETIME或TIMESTAMP类型)进行有效比较的常见问题。我们将探讨如何利用SQL的内置函数如NOW()或CURDATE(),实现高效、精确的日期时间范围查询,以识别最新数据或特定日期的…

    2025年12月10日
    000
  • 如何部署PHP WebSocket服务:理解共享主机限制与VPS解决方案

    在CPanel等共享主机环境中部署PHP WebSocket服务面临固有挑战,主要因为缺乏专用端口和对长时间运行进程的支持。本文将深入探讨共享主机不适合运行WebSocket服务的原因,并明确指出使用虚拟私有服务器(VPS)如Amazon EC2或DigitalOcean VPS是实现此功能的推荐解…

    2025年12月10日
    000
  • 在 Laravel API 中实现 WebSocket:配置与连接指南

    本文旨在详细指导如何在 Laravel API 中实现 WebSocket 功能,重点解决前端与后端分离部署时,Laravel Echo 连接 WebSocket 服务器可能遇到的 404 错误。我们将深入探讨 Laravel Echo 的关键配置参数,确保客户端能够正确连接到 WebSocket …

    2025年12月10日
    000
  • Laravel API WebSocket集成指南:解决404连接问题

    本文旨在提供一份全面的Laravel API WebSocket集成教程,重点解决在配置和连接过程中常见的404错误。我们将详细讲解如何使用Laravel Echo正确配置客户端连接参数,包括wsHost、wsPort和authEndpoint,并探讨确保WebSocket服务稳定运行的关键服务器端…

    2025年12月10日
    000
  • Laravel API 中 WebSocket 的实现与常见连接问题解析

    本教程详细指导如何在 Laravel API 中实现 WebSockets,重点解决连接时遇到的 404 错误。通过配置 Laravel Echo 的 authEndpoint、wsHost 和 wsPort,确保前端与 WebSocket 服务器及认证服务正确通信,从而实现稳定高效的实时功能。 L…

    2025年12月10日
    000
  • 解决Laravel API中WebSocket连接404错误的完整指南

    本教程旨在解决Laravel API中实现WebSocket时常见的404连接错误。文章将详细阐述如何通过正确配置Laravel Echo客户端来建立稳定的WebSocket连接,特别是在前端与后端宿主环境不同时,并深入解析关键配置参数,提供实用的实施要点和故障排除建议,确保您的WebSocket服…

    2025年12月10日
    000
  • 加密货币量化交易入门: 策略类型、工具选择与代码实现基础指南

    趋势跟踪通过均线交叉判断方向,结合ATR止损;均值回归利用布林带捕捉价格偏离;套利策略捕获交易所价差,需低延迟执行;使用Python、ccxt、Pandas等工具实现高效开发与稳定运行。 binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注…

    2025年12月9日
    000
  • 加密货币交易中的“滑点”是什么?如何在大额交易中避免?

    滑点是交易中预期价格与实际成交价的偏差,主要由市场流动性不足和网络延迟导致。1、通过观察订单簿深度和选择高流动性主流币种可降低滑点风险。2、使用限价单并拆分大额订单,能有效控制执行成本。3、避开高波动时段、利用冰山订单及在交易高峰时段操作,优化执行策略。4、借助API交易机器人、动态滑点参数和TWA…

    2025年12月9日
    000
  • 币圈量化交易数据平台_主流币圈量化交易数据平台是哪些

    对于加密货币投资者而言,量化交易是执行复杂策略、捕捉市场机会的强大工具。选择一个稳定、高效且数据丰富的平台是量化交易成功的基石,本文将为您盘点并介绍当前主流的币圈量化交易数据平台,帮助您做出明智选择。 主流币圈量化交易数据平台排名 1. 币安 (Binance) 官网直达: 作为全球交易量最大的加密…

    2025年12月9日
    000
  • 币安开发者平台:Binance官网与API入口 币安App最新版v3.6.6下载

    币安(binance)开发者平台为开发者与机构提供完善的api接口、文档与密钥管理能力,适用于自动化交易、行情订阅与账户管理。本文将简要介绍币安官网的开发者/api入口,并说明如何获取api key与配置安全设置,同时附上币安app最新版 v3.6.6 的下载安装说明,帮助你快速上手。 币安(Bin…

    2025年12月9日
    000
  • 构建VSCode金融量化交易环境与实时数据回测

    搭建基于VSCode的金融量化交易环境需先配置Python及VSCode相关扩展,再创建虚拟环境并安装依赖;接着通过AKShare等工具接入历史与实时数据;随后使用Backtrader构建双均线策略并回测;最后对接实盘接口实现自动化交易,形成完整工作流。 搭建一个基于VSCode的金融量化交易环境,…

    2025年12月6日 开发工具
    000
  • PHP实时输出与Ajax轮询哪个更好_PHP实时输出与Ajax轮询对比

    PHP实时输出适合单向、短周期任务进度展示,通过ob_flush()和flush()实现伪实时;Ajax轮询适用于双向、持续更新场景,客户端定时拉取数据。前者节省HTTP请求但耗服务器资源,后者兼容性好但有延迟和带宽浪费。实际应用中,耗时任务推荐PHP输出,交互系统建议Ajax轮询或升级至SSE/W…

    2025年12月5日
    000
  • Swoole怎么实现WebSocket实时聊天

    使用Swoole实现WebSocket实时聊天,核心是利用其异步常驻内存特性构建高性能服务器。1. 创建SwooleWebSocketServer实例监听9502端口,通过on(‘open’)、on(‘message’)、on(‘close…

    2025年12月4日
    000
  • 如何让看房日记新访客显示在系统里

    一、优化访客信息采集功能 确保系统能够完整、精准地记录每一位访问看房日记页面的用户信息。需涵盖访客的基本资料,如真实姓名、联系电话或电子邮箱,并精确记录其进入页面的具体时间。系统应在访客打开页面时自动获取并保存上述数据,为后续的信息展示与管理操作提供可靠的数据支撑。 二、构建访客信息展示界面 设计专…

    2025年12月3日
    000
  • Swoole的onClose事件在什么时候触发

    onClose事件在Swoole中用于处理TCP或WebSocket连接关闭,客户端或服务端断开时均会触发。当客户端发送FIN包,Swoole检测到连接状态变化后立即通知Worker进程执行回调。自1.7.7版本起,可在回调内调用connection_info获取连接信息。Swoole保证onCon…

    2025年12月3日
    500

发表回复

登录后才能评论
关注微信