GatewayWorker实现指定用户之间聊天

1 篇文章 0 订阅

首先去官网下载GatewayWorker:https://www.workerman.net/download

一、文件结构
在这里插入图片描述
① index.php是我创建的主要用于本次项目的讲解,后缀也可以用html。
② start_for_win.bat是window启动socket服务器的文件,双击启动。linux系统运行start.php就行。

二、找到start_gateway.php文件,将协议改成Websocket

$gateway = new Gateway("Websocket://0.0.0.0:8282");

三、在index.php文件连接Websocket

先启动start_for_win.bat
在这里插入图片描述

<script>
	var ws = new WebSocket('ws://127.0.0.1:8282');
	ws.onmessage = function (e) {
		console.log(e);
	}
</script>

四、Events.php发起初始化

//当客户端连接时触发
public static function onConnect($client_id)
{
	Gateway::sendToClient($client_id, json_encode([
		'type' => 'init',
		'client_id' => $client_id
	]));
}

五、index.php接收初始化,发起绑定用户

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<script src="http://code.jquery.com/jquery-2.1.4.min.js"></script>
</head>
<body>
	<input id="fromId" type="hidden" value="<?php echo $_GET['fromId']?>">
	<input id="toId" type="hidden" value="<?php echo $_GET['toId']?>">
	<input type="text" id="text">
	<button id="send">发送</button>
	<div id="div"></div>
</body>
</html>
<script>
	var fromId = $('#fromId').val();
	var toId = $('#toId').val();
	
	var ws = new WebSocket('ws://127.0.0.1:8282');
	ws.onmessage = function (e) {
		var message = eval("("+ e.data +")");
		switch (message.type) {
			case "init":
				var bindObj = {
					type:"bind",
					fromId:fromId
				}
				var bindMsg = JSON.stringify(bindObj);
				ws.send(bindMsg);
				return;	
		}	
	}
</script>

注意:用了eval函数要将Events.php里的发送数据改成json数据。

六、Events.php接收绑定请求,绑定用户

//当客户端发来消息时触发
public static function onMessage($client_id, $message)
{
	$list = json_decode($message,true);
	if (!$list) return;
	switch ($list['type']) {
		case 'bind':
			$fromId = $list['fromId'];
			Gateway::bindUid($client_id,$fromId);
			return;  
}

七、index.php发送消息

$('#send').click(function () {
	var value = $('#text').val();
	var obj = {
		type:"say",
		data:value,
		fromId:fromId,
		toId:toId
	}
	var data = JSON.stringify(obj);
	ws.send(data);
	var html = '<div style="width: 100px;height: 50px;background-color: pink;">'+ value +'</div>';
	$("#div").append(html);
	$('#text').val('');
});

八、Events.php接收信息

//当客户端发来消息时触发
public static function onMessage($client_id, $message)
{
	$list = json_decode($message,true);
	if (!$list) return;
	switch ($list['type']) {
		case 'bind':
			$fromId = $list['fromId'];
			Gateway::bindUid($client_id,$fromId);
			return;  
		case 'say':
			$content = $list['data'];
			$fromId = $list['fromId'];
			$toId = $list['toId'];
			$data = [
				'type' => 'text',
				'id' => $client_id,
				'data' => $content,
				'fromId' => $fromId,
				'toId' => $toId
			];
			Gateway::sendToUid($toId,json_encode($data));
			return;
	}
	// 向所有人发送 
    //Gateway::sendToAll("测试");	
}

九、index.php处理

ws.onmessage = function (e) {
	console.log(e);
	var message = eval("("+ e.data +")");
	switch (message.type) {
		case "init":
			var bindObj = {
				type:"bind",
				fromId:fromId
			}
			var bindMsg = JSON.stringify(bindObj);
			ws.send(bindMsg);
			return;
		case 'text':
			var html = '<div style="width: 100px;height: 50px;background-color: pink;">'+ message.data +'</div>';
			$("#div").append(html);
			return;	
	}		
}

补充:每一次修改Events.php文件都要重启socket服务

打开浏览器两个窗口,分别传index.php?fromId=1&toId=2和index.php?fromId=2&toId=1就可以实现聊天了

参考链接
https://www.bilibili.com/video/av71149776?from=search&seid=15972172467492065501

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
GatewayWorker是一种基于事件驱动的高性能网络通信框架,可以用于实现长连接的应用,比如即时通讯、推送服务等。下面是一个简单的使用GatewayWorker实现数据传输的示例: 1. 安装GatewayWorker: ```bash composer require workerman/gateway-worker ``` 2. 创建一个GatewayWorker应用: ```php <?php use Workerman\Worker; use GatewayWorker\Gateway; // 创建一个GatewayWorker实例,监听端口为1234 $gateway = new Gateway("websocket://0.0.0.0:1234"); // 启动GatewayWorker Worker::runAll(); ``` 3. 编写客户端代码: ```html <!-- 客户端html页面 --> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>GatewayWorker Test</title> </head> <body> <input type="text" id="message" placeholder="请输入消息"> <button onclick="send()">发送</button> <ul id="messages"></ul> <script> var ws = new WebSocket("ws://localhost:1234"); ws.onmessage = function(event) { var li = document.createElement("li"); li.innerText = event.data; document.getElementById("messages").appendChild(li); }; function send() { var message = document.getElementById("message").value; ws.send(message); } </script> </body> </html> ``` 4. 编写服务端代码: ```php <?php use Workerman\Worker; use GatewayWorker\Gateway; // 创建一个GatewayWorker实例,监听端口为1234 $gateway = new Gateway("websocket://0.0.0.0:1234"); // 当客户端连接时触发 $gateway->onConnect = function($client_id) { echo "Client connected: $client_id\n"; }; // 当客户端发来消息时触发 $gateway->onMessage = function($client_id, $message) use ($gateway) { echo "Message received from client $client_id: $message\n"; // 将消息发送给所有客户端 $gateway->sendToAll("Message from $client_id: $message"); }; // 启动GatewayWorker Worker::runAll(); ``` 在浏览器中打开客户端页面,输入消息并点击“发送”按钮,就能将消息发送到服务端并在客户端页面上显示出来。服务端会将收到的消息广播给所有客户端。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值