`
wjlgryx
  • 浏览: 308657 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

HTML5 WebSockets

阅读更多
HTML5之中一个很酷的新特性就是WebSockets,它可以让我们无需AJAX请求即可与服务器端对话。今天彬Go将让大家通过Php环境的服务器端运行WebSocket,创建客户端并通过WebSockets协议发送和接收服务器端信息。
什么是WebSockets?
WebSockets是在一个(TCP)接口进行双向通信的技术,PUSH技术类型。同时WebSockets仍将基于W3C标准,目前为止,Chrome和Safari的最新版本浏览器已经支持WebSockets了。
WebSockets将会替代什么?
WebSockets可以替代Long Polling(PHP服务端推送技术),这是一个有趣的概念。客户端发送一个请求到服务器,现在,服务器端并不会响应还没准备好的数据,它会保持连接的打开状态直到最新的数据准备就绪发送,之后客户端收到数据,然后发送另一个请求。这有它的好处:减少任一连接的延迟,当一个连接已经打开时就不需要创建另一个新的连接。但是Long-Polling并不是什么花俏技术,他仍有可能发生请求暂停,因此会需要建立新的连接。
一些AJAX应用使用上述技术-这经常是归因于低资源利用。
试想一下,如果服务器在早晨会自启动并发送数据到那些希望接收而不用提前建立一些连接端口的客户端,这是一件多棒的事情啊!欢迎来到PUSH技术的世界!
第一步:搞定WebSocket服务器
这篇教程会把更多的精力放在客户端的创建而不是服务器端的执行等操作。
我使用基于windows 7的XAMPP来实现本地运行PHP。phpwebsockets是PHP WebSocket服务器。(以我的经验这个版本存在一些小问题,我已对它做了些修改并上传源文件共享给大家)下面的这些不同版本也可以实现WebSocket,如果某个不能用,你可以试试其它版本或者继续看下面的教程。
jWebSocket (Java)
web-socket-ruby (ruby)
Socket IO-node (node.js)
启动Apache服务器

第二步:修改URLs和端口
根据你之前的安装修改服务器,下面是setup.class.php中的例子:
public function __construct($host='localhost',$port=8000,$max=100) 

    $this->createSocket($host,$port); 
}
浏览文件并在适当情况下进行更改。
第三步:开始创建客户端
下面来创建基本模板,这是我的client.php文件:
<!DOCTYPE html> 
<html> 
<head> 
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script> 
 
<title>WebSockets Client</title> 
 
</head> 
<body> 
<div id="wrapper"> 
 
    <div id="container"> 
 
        <h1>WebSockets Client</h1> 
 
        <div id="chatLog"> 
 
        </div><!-- #chatLog --> 
        <p id="examples">e.g. try 'hi', 'name', 'age', 'today'</p> 
 
        <input id="text" type="text" /> 
        <button id="disconnect">Disconnect</button> 
 
    </div><!-- #container --> 
 
</div> 
</body> 
</html>

我们已经创建里基本模板:一个chat log容器,一个input输入框和一个断开连接的按钮。
第四步:添加一些CSS
没什么花俏代码,只是处理一下标签的样式。
body { 
    font-family:Arial, Helvetica, sans-serif; 

#container{ 
    border:5px solid grey; 
    width:800px; 
    margin:0 auto; 
    padding:10px; 

#chatLog{ 
    padding:5px; 
    border:1px solid black; 

#chatLog p { 
    margin:0; 

.event { 
    color:#999; 

.warning{ 
    font-weight:bold; 
    color:#CCC; 
}
第五步:WebSocket事件
首先让我们尝试并理解WebSocket事件的概念:

WebSocket事件:
我们将使用三个WebSocket事件:
onopen: 当接口打开时
onmessage: 当收到信息时
onclose: 当接口关闭时
我们如何来实现呢?
首先创建WebSocket对象
var socket = new WebSocket("ws://localhost:8000/socket/server/startDaemon.php");
然后向下面这样检测事件
socket.onopen = function(){ 
    alert("Socket has been opened!"); 
}
当我们收到信息时这样做:
socket.onmessage = function(msg){ 
    alert(msg); //Awesome! 
}
但我们还是尽量避免使用alert,现在我们可以把我们学的东西整合到客户端页面中了。
第六步:JavaScript
首先我们将代码放到jQuery 的 document.ready函数中,然后我们还要检查用户的浏览器是否支持WebSocket。如果不支持,我们就添加一个链向Chrome浏览器页面的链接。
$(document).ready(function() { 
    if(!("WebSocket" in window)){ 
        $('#chatLog, input, button, #examples').fadeOut("fast"); 
        $('<p>Oh no, you need a browser that supports WebSockets. How about <a href="http://www.google.com/chrome">Google Chrome</a>?</p>').appendTo('#container'); 
    }else{ 
 
    //The user has WebSockets 
 
    connect(); 
 
    function connect(){ 
        //the connect function code is below 
 
    } 
});
如你所见,如果用户浏览器支持WebSocket,我们将执行connect()函数。这里是核心功能,我们将开始创建open、close和receive事件。
我们将在我们的服务器定义URL。
1
2 var socket; 
var host = "ws://localhost:8000/socket/server/startDaemon.php";
你可能会发现URL中怎么没有http?恩,是的,这是一个WebSocket URL,使用了不同的协议。下面是URL分解图示:

下面让我们继续完成connect()函数,我们将代码放入try/catch块,这样如果代码出现问题,我们能让用户知道。我们创建WebSocket,并将信息传递到message()函数,之后会做讲解。我们创建我们的onopen、onmessage和onclose函数. 需要注意的是我们为用户提供了端口状态,这并不是必需的,但我们把它放进来主要是为了方便调试。
CONNECTING = 0
OPEN = 1
CLOSED = 2
function connect(){ 
    try{ 
 
    var socket; 
    var host = "ws://localhost:8000/socket/server/startDaemon.php"; 
    var socket = new WebSocket(host); 
 
        message('<p class="event">Socket Status: '+socket.readyState); 
 
        socket.onopen = function(){ 
             message('<p class="event">Socket Status: '+socket.readyState+' (open)'); 
        } 
 
        socket.onmessage = function(msg){ 
             message('<p class="message">Received: '+msg.data); 
        } 
 
        socket.onclose = function(){ 
             message('<p class="event">Socket Status: '+socket.readyState+' (Closed)'); 
        }            
 
    } catch(exception){ 
         message('<p>Error'+exception); 
    } 
}
message()函数很简单, 它将我们想展现给用户的文本填入chat log容器内。 我们在socket事件函数中为段落(<p>)标签创建适当的class,我们在message函数中只有一个段落结束标签。
1
2
3 function message(msg){ 
    $('#chatLog').append(msg+'</p>'); 
}
目前的成果
如果你已按上面教程按部就班的做的话,很好,我们已经创建了 HTML/CSS模板、创建并建立Websocket连接、通过创建连接保持用户的进展更新。

第七步:发送数据
现在我们已经有了提交按钮,但我们还需要监听用户按下键盘的事件,并运行send函数,下面的’13′便是回车键对应的ASCII码。
1
2
3
4
5 $('#text').keypress(function(event) { 
    if (event.keyCode == '13') { 
        send(); 
    } 
});
下面是send()函数:
function send(){ 
 
    var text = $('#text').val(); 
    if(text==""){ 
        message('<p class="warning">Please enter a message'); 
        return ; 
    } 
    try{ 
        socket.send(text); 
        message('<p class="event">Sent: '+text) 
    } catch(exception){ 
    message('<p class="warning"> Error:' + exception); 
    } 
 
    $('#text').val(""); 
 
}
下面我们需要:
1 socket.send();
那些额外的代码做了以下工作:检测用户是否什么都没输入却仍点击返回、清空input输入框、执行message()函数。
关闭Socket
关闭Socket操作相当简单,添加对断开连接按钮的click事件监听就可以。
1
2
3 $('#disconnect').click(function(){ 
    socket.close(); 
});

完整JavaScript代码
$(document).ready(function() { 
 
  if(!("WebSocket" in window)){ 
  $('#chatLog, input, button, #examples').fadeOut("fast"); 
  $('<p>Oh no, you need a browser that supports WebSockets. How about <a href="http://www.google.com/chrome">Google Chrome</a>?</p>').appendTo('#container'); 
  }else{ 
      //The user has WebSockets 
 
      connect(); 
 
      function connect(){ 
          var socket; 
          var host = "ws://localhost:8000/socket/server/startDaemon.php"; 
 
          try{ 
              var socket = new WebSocket(host); 
 
              message('<p class="event">Socket Status: '+socket.readyState); 
 
              socket.onopen = function(){ 
                 message('<p class="event">Socket Status: '+socket.readyState+' (open)'); 
              } 
 
              socket.onmessage = function(msg){ 
                 message('<p class="message">Received: '+msg.data); 
              } 
 
              socket.onclose = function(){ 
                message('<p class="event">Socket Status: '+socket.readyState+' (Closed)'); 
              }          
 
          } catch(exception){ 
             message('<p>Error'+exception); 
          } 
 
          function send(){ 
              var text = $('#text').val(); 
 
              if(text==""){ 
                  message('<p class="warning">Please enter a message'); 
                  return ; 
              } 
              try{ 
                  socket.send(text); 
                  message('<p class="event">Sent: '+text) 
 
              } catch(exception){ 
                 message('<p class="warning">'); 
              } 
              $('#text').val(""); 
          } 
 
          function message(msg){ 
            $('#chatLog').append(msg+'</p>'); 
          } 
 
          $('#text').keypress(function(event) { 
              if (event.keyCode == '13') { 
                send(); 
              } 
          });    
 
          $('#disconnect').click(function(){ 
             socket.close(); 
          }); 
 
      }//End connect 
 
  }//End else 
 
});
第九步:运行WebSocket服务器
我们要输入一些命令行,XAMPP提供了比较方便的shell选项。点击XAMPP控制面板的’shell’按钮并输入:
php -q path\to\server.php
现在你已经运行了WebSocket服务器!

大功告成!

分享到:
评论

相关推荐

    HTML5 WebSockets 基础使用教程加示例

    HTML5 WebSockets 是一种在客户端和服务器之间建立实时、双向通信通道的技术。它使得Web应用程序可以像桌面应用一样实时地收发数据,无需频繁地使用HTTP请求来更新页面。这个基础使用教程将涵盖WebSockets的核心概念...

    HTML5 WebSockets基础使用教程

    ### HTML5 WebSockets基础使用教程 #### 一、引言 HTML5为现代Web开发引入了许多激动人心的新特性,其中WebSockets是一项值得关注的重要技术。它允许客户端和服务器之间建立持久连接,从而实现双向实时通信,这在很...

    WebSocket.Essentials.Building.Apps.with.HTML5.WebSockets

    This book is for web developers who want to learn and implement WebSocket to create interesting apps for modern browsers, leveraging the capabilities of HTML5 with WebSockets. In Detail WebSocket ...

    HTML5WebSockets基础使用教程

    HTML5 WebSockets 是一种在客户端与服务器之间建立持久、双向通信的技术,它基于TCP协议,使得实时数据传输成为可能。传统的HTTP协议是单向的,即由客户端发起请求,服务器响应。但WebSockets允许服务器主动推送给...

    完整版《HTML5高级程序设计》2

    6.2 HTML5 WebSockets的浏览器支持情况 120 6.3 编写简单的Echo WebSocket服务器 120 6.4 使用HTML5 WebSockets API 126 6.4.1 浏览器支持情况检测 126 6.4.2 API的基本用法 127 6.5 创建HTML5 WebSockets应用程序 ...

    完整版《HTML5高级程序设计》5

    6.2 HTML5 WebSockets的浏览器支持情况 120 6.3 编写简单的Echo WebSocket服务器 120 6.4 使用HTML5 WebSockets API 126 6.4.1 浏览器支持情况检测 126 6.4.2 API的基本用法 127 6.5 创建HTML5 WebSockets应用程序 ...

    HTML5高级程序设计

    6.2 html5 websockets的浏览器支持情况 120 6.3 编写简单的echo websocket服务器 120 6.4 使用html5 websockets api 126 6.4.1 浏览器支持情况检测 126 6.4.2 api的基本用法 127 6.5 创建html5 websockets应用...

    完整版《HTML5高级程序设计》4

    6.2 HTML5 WebSockets的浏览器支持情况 120 6.3 编写简单的Echo WebSocket服务器 120 6.4 使用HTML5 WebSockets API 126 6.4.1 浏览器支持情况检测 126 6.4.2 API的基本用法 127 6.5 创建HTML5 WebSockets应用程序 ...

    HTML5程序设计(第2版).[荷]Peter Lubbers(带详细书签).pdf

    7.4 创建HTML5 WebSockets应用程序 158 7.4.1 编写HTML文件 159 7.4.2 添加WebSocket代码 160 7.4.3 添加Geolocation代码 160 7.4.4 合并所有内容 161 7.4.5 终代码 163 7.5 小结 165 第8章 Forms API 166 ...

    html5双向通讯示例

    HTML5的双向通讯技术主要指的是WebSockets协议,它为客户端和服务器之间的实时、低延迟、双向通信提供了标准。在传统的HTTP协议下,浏览器与服务器的通信是基于请求-响应模型,而WebSockets打破了这一限制,实现了...

    HTML5高级程序设计.part5

    6.2 HTML5 WebSockets的浏览器支持情况 120 6.3 编写简单的Echo WebSocket服务器 120 6.4 使用HTML5 WebSockets API 126 6.4.1 浏览器支持情况检测 126 6.4.2 API的基本用法 127 6.5 创建HTML5 WebSockets应用...

    完整版《HTML5高级程序设计》3

    6.2 HTML5 WebSockets的浏览器支持情况 120 6.3 编写简单的Echo WebSocket服务器 120 6.4 使用HTML5 WebSockets API 126 6.4.1 浏览器支持情况检测 126 6.4.2 API的基本用法 127 6.5 创建HTML5 WebSockets应用程序 ...

    HTML5高级程序设计.part4

    6.2 HTML5 WebSockets的浏览器支持情况 120 6.3 编写简单的Echo WebSocket服务器 120 6.4 使用HTML5 WebSockets API 126 6.4.1 浏览器支持情况检测 126 6.4.2 API的基本用法 127 6.5 创建HTML5 WebSockets应用...

    HTML5高级程序设计.part1

    6.2 HTML5 WebSockets的浏览器支持情况 120 6.3 编写简单的Echo WebSocket服务器 120 6.4 使用HTML5 WebSockets API 126 6.4.1 浏览器支持情况检测 126 6.4.2 API的基本用法 127 6.5 创建HTML5 WebSockets应用...

    HTML5高级程序设计.part2

    6.2 HTML5 WebSockets的浏览器支持情况 120 6.3 编写简单的Echo WebSocket服务器 120 6.4 使用HTML5 WebSockets API 126 6.4.1 浏览器支持情况检测 126 6.4.2 API的基本用法 127 6.5 创建HTML5 WebSockets应用...

    HTML5高级程序设计.part3

    6.2 HTML5 WebSockets的浏览器支持情况 120 6.3 编写简单的Echo WebSocket服务器 120 6.4 使用HTML5 WebSockets API 126 6.4.1 浏览器支持情况检测 126 6.4.2 API的基本用法 127 6.5 创建HTML5 WebSockets应用...

    课程HTML5资料个人专用.zip

    3. **应用程序**:`websocket_student.exe` 暗示了一个使用HTML5 WebSockets技术的实验项目。WebSockets提供了一种双向通信方式,使得服务器与客户端能实时交互,常用于在线聊天、实时游戏等场景。通过运行这个程序...

    HTML5VNC客户端noVNC.zip

    noVNC 是一个 HTML5 VNC 客户端,采用 HTML 5 WebSockets, Canvas 和 JavaScript 实现,noVNC 被普遍用在各大云计算、虚拟机控制面板中,比如 OpenStack Dashboard 和 OpenNebula Sunstone 都用的是 noVNC....

Global site tag (gtag.js) - Google Analytics