websoket的簡單應用

hwk_yellow發表於2016-11-16

第一步。下載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位顏色編碼後,所有頁面背景顏色均會改變。

相關文章