websoket的简单应用

本文介绍如何使用Swoole PHP扩展搭建WebSocket服务器,并通过示例代码演示如何实现客户端与服务器之间的实时通信。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第一步。下载swoole

[php]  view plain  copy
  1. wget https://pecl.php.net/get/swoole-1.8.11.tgz  
  2. tar zxvf swoole-1.8.11.tgz  
  3. cd swoole-1.8.11  
  4. phpize  
  5. ./configure  
  6. make && make install  

第二步,配置PHP.ini

[php]  view plain  copy
  1. vi /etc/php.ini  
  2. 添加以下内容  
  3. extension=swoole.so  

重启nginx/apache


在web根目录

[php]  view plain  copy
  1. vi server.php  
  2.   
  3.   
  4. <?php  
  5.   
  6. //创建websocket服务器对象,监听0.0.0.0:9502端口  
  7. $ws = new swoole_websocket_server("0.0.0.0", 9502);  
  8.   
  9. //监听WebSocket连接打开事件  
  10. $ws->on('open'function ($ws$request) {  
  11.     var_dump($request->fd, $request->get, $request->server);  
  12.     $GLOBALS['fd'][] = $request->fd;  
  13.     //$ws->push($request->fd, "hello, welcome\n");  
  14. });  
  15.   
  16. //监听WebSocket消息事件  
  17. $ws->on('message'function ($ws$frame) {  
  18.     echo "Message: {$frame->data}\n";  
  19.       foreach($GLOBALS['fd'as $key => $val){  
  20.             $ws->push($val,$frame->data);  
  21.       }  
  22.    //$ws->push($frame->fd, "{$frame->data}");  
  23. });  
  24.   
  25. //监听WebSocket连接关闭事件  
  26. $ws->on('close'function ($ws$fd) {  
  27.     echo "client-{$fd} is closed\n";  
  28. });  
  29.   
  30. $ws->start();  

启动服务

[php]  view plain  copy
  1. php server.php  

本地新建文件

[php]  view plain  copy
  1. <!DOCTYPE html>  
  2. <html lang="en">  
  3. <head>  
  4.     <meta charset="UTF-8">  
  5.     <title></title>  
  6. </head>  
  7. <body>  
  8.     <input type="text" id="color">  
  9.     <button onclick="doSend()">变色</button>  
  10. </body>  
  11. </html>  
  12. <script>  
  13. var wsServer = 'ws://192.168.1.212:9502';   //ip地址为服务器IP地址  
  14. var websocket = new WebSocket(wsServer);  
  15. websocket.onopen = function (evt) {  
  16.     console.log("Connected to WebSocket server.");  
  17. };  
  18.   
  19. websocket.onclose = function (evt) {  
  20.     console.log("Disconnected");  
  21. };  
  22.   
  23. websocket.onmessage = function (evt) {  
  24.     //alert(evt.data)  
  25.      document.body.style.backgroundColor="#"+evt.data;  
  26.     console.log('Retrieved data from server: ' + evt.data);  
  27. };  
  28.   
  29. websocket.onerror = function (evt, e) {  
  30.     console.log('Error occured: ' + evt.data);  
  31. };  
  32. function doSend() {   
  33.         var color = document.getElementById("color").value;  
  34.         websocket.send(color);   
  35. }   
  36. </script>  

测试

可以多开几个页面,在任意一个页面输入6位颜色编码后,所有页面背景颜色均会改变。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值