HTML5-WebSocket技术学习(2)

上一篇介绍了websocket的基本用法.这篇介绍websocket的一个框架: socket.io

socket.io是一个既可以用在客户端又可以用在服务器端的框架. 本篇介绍socket.io在客户端和node后端的基本用法

首先进入项目的根目录,然后执行 npm install socket.io

客户端:

1.链入socket.io.js:

<script type="text/javascript" src="/socket.io/socket.io.js"></script>
<script type="text/javascript" src="socket.io/socket.io.js"></script>

特别注意,不需要创建一个文件夹socket.io,再在里面放入socket.io.js这个文件.

只要在根目录下在npm install socket.io,就可以了.上面两种写法都ok,但是不可以写 src="socket.io.js"

2.创建一个连接:

var iosocket = io.connect();

3.连接事件:

iosocket.on(‘connect‘,function(e){...})

4.接收到数据事件:

iosocket.on(‘message‘,function(data){
   console.log(data)
})

data就是接收到的数据

5.断开连接事件:

iosocket.on(‘disconnect‘, function(e){...});

6.向服务器端发送数据:

iosocket.send(data)

data就是要发送的数据

服务器端:

1.获取socket.io模块:

var socketio = require(‘socket.io‘)

2.创建一个服务端:

var server = http.createServer(function(req, res) {
  ...
}).listen(3000, function() {
  console.log(‘Listening at: http://localhost:3000‘);
});

3.创建服务器端对应的socket:

var io = socketio(server);

4.连接,收发数据:

io.on(‘connection‘,function(socket){
    socket.on(‘message‘,function(data){
        console.log(‘Message Received: ‘, data);
        socket.broadcast.emit(‘message‘, data);
    })
});

下面举个完整的实例,模拟两人聊天:

index.html:

<html>
<head>
  <meta charset="utf-8">
  <link rel="stylesheet" href="http://cdn.bootcss.com/bootstrap/3.3.1/css/bootstrap.min.css"/>
  <script type="text/javascript" src="http://cdnimg.ocj.com.cn/common/js/jquery-1.10.2.min.js"></script>
  <script type="text/javascript" src="socket.io/socket.io.js"></script>
  <style>
    .bunny {
      color:#AF4442
    }
    .cat {
      color:#3170A9
    }
  </style>
  <script>
    $(function(){

      var name;

      $(‘#myName‘).keypress(function(event) {
        if(event.which == 13) {
          event.preventDefault();
          name = $(this).val();
          var myname = $(‘<p><span class="label label-default">‘+name+‘</span></p>‘);
          $(this).parent(‘.form-group‘).before(myname);
          $(this).parent(‘.form-group‘).remove();

        }
      });

      var iosocket = io.connect();

      iosocket.on(‘connect‘, function () {
        $(‘.container‘).prepend($(‘<div class="alert alert-success" role="alert">已连接</div>‘));
      });

      iosocket.on(‘message‘, function(message) {
        var messages = message.split(‘;‘);
        $(‘#incomingChatMessages‘).append($(‘<li class=‘+messages[0]+‘></li>‘).text(messages[0]+‘ say:‘+messages[1]));
      });

      iosocket.on(‘disconnect‘, function() {
        $(‘.container‘).prepend($(‘<div class="alert alert-danger" role="alert">已断开</div>‘));
      });

      $(‘#outgoingChatMessage‘).keypress(function(event) {
        if(event.which == 13) {
          event.preventDefault();
          iosocket.send(name+‘;‘+$(‘#outgoingChatMessage‘).val());
          $(‘#incomingChatMessages‘).append($(‘<li class=‘+name+‘></li>‘).text(name+‘ say:‘+$(‘#outgoingChatMessage‘).val()));
          $(‘#outgoingChatMessage‘).val(‘‘);
        }
      });
    });
  </script>
</head>
<body>
<div class="container">

  Incoming Chat:&nbsp;<ul id="incomingChatMessages"></ul>
  <br />
  <div class="form-group">
    <label for="myName">name:</label>
    <input type="text" class="form-control" id="myName" placeholder="Enter Your Name">
  </div>
  <div class="form-group">
    <label for="outgoingChatMessage">enter:</label>
    <input type="text" class="form-control" id="outgoingChatMessage" placeholder="Enter info">
  </div>
</div>

</body>
</html>

分析:

1.创建一个name变量,用于保存用户输入的昵称.在这里都是虚假数据,所以只能输入cat,或者bunny(因为定义的样式是这两个类名),其中,cat发送的消息是蓝色的,bunny发送的消息是红色的.

2.先输入用户名,保存当前用户名(相当于聊天中的登录)

3.创建socket

4.连接成功的时候,显示提示"已连接"

5.接收数据成功的时候,把接收到的对方发送的消息插入到聊天对话中

6.按回车键发送消息,把自己发送的消息也插入到聊天对话中

7.连接断开的时候,显示提示"已断开"

app.js:

var fs = require(‘fs‘)
    , http = require(‘http‘)
    , socketio = require(‘socket.io‘);

var server = http.createServer(function(req, res) {
  res.writeHead(200, { ‘Content-type‘: ‘text/html‘});
  res.end(fs.readFileSync(__dirname + ‘/index.html‘));
}).listen(3000, function() {
  console.log(‘Listening at: http://localhost:3000‘);
});

var io = socketio(server);
io.on(‘connection‘,function(socket){
    socket.on(‘message‘,function(data){
        console.log(‘Message Received: ‘, data);
        socket.broadcast.emit(‘message‘, data);
    })
});

分析:

1.获取socket.io模块

2.创建服务器端,读取index.html内容.

3.创建socket.io的实例,传入server

4.监听connection事件,添加回调

5.监听message事件,添加回调,把接收到的信息再发出去

这个demo运行以后大概是这样的:

打开一个火狐,一个chrome:

分别输入用户名,cat和bunny:

输入用户名后:

然后就猫猫和兔兔就可以开始聊天啦~~

今天就到这里,socket.io还有很多api,很多其他用法,以后会不断深入研究~~~

完整代码:https://github.com/OOP-Code-Bunny/html5/tree/master/nodeWebsocket

时间: 2024-10-13 03:32:18

HTML5-WebSocket技术学习(2)的相关文章

Html5 WebSocket 技术介绍

WebSocket是html5规范新引入的功能,用于解决浏览器与后台服务器双向通讯的问题,使用WebSocket技术,后台可以随时向前端推送消息,以保证前后台状态统一,在传统的无状态HTTP协议中,这是“无法做到”的. 传统服务端推(server push)技术 WebSocket提出之前,为了解决后台推送消息到前台的需求,提出了一些解决方案,这些方案使用已有的技术(如ajax,iframe,flashplayer,java applet …),通过一些变通的处理来实现. 简单轮询 最简单的是前

打通B/S与C/S !让HTML5 WebSocket与.NET Socket公用同一个服务端!

随着HTML5 WebSocket技术的日益成熟与普及,我们可以借助WebSocket来更加方便地打通BS与CS -- 因为B/S中的WebSocket可以直接连接到C/S的服务端,并进行双向通信.如下图所示: 一.对Socket Server的要求 我们可以尝试让Socket Server透明地支持WebSocket客户端,所谓透明的意思是,服务端开发人员不用关心客户端究竟是什么类型,而是可以统一的接收数据.处理数据.发送数据.为了做到这一点,我们可以构建一个服务端框架,让框架完成透明化的工作

Demo源码放送:打通B/S与C/S !让HTML5 WebSocket与.NET Socket公用同一个服务端!

随着HTML5 WebSocket技术的日益成熟与普及,我们可以借助WebSocket来更加方便地打通BS与CS -- 因为B/S中的WebSocket可以直接连接到C/S的服务端,并进行双向通信.如下图所示: 一.对Socket Server的要求 我们可以尝试让Socket Server透明地支持WebSocket客户端,所谓透明的意思是,服务端开发人员不用关心客户端究竟是什么类型,而是可以统一的接收数据.处理数据.发送数据.为了做到这一点,我们可以构建一个服务端框架,让框架完成透明化的工作

【猪猪-前端】微信打飞机高质量Demo,学习HTML5+Canvas技术编写,下载即可使用,注释齐全。

原文:[猪猪-前端]微信打飞机高质量Demo,学习HTML5+Canvas技术编写,下载即可使用,注释齐全. 源代码下载地址:http://www.zuidaima.com/share/1553027668610048.htm //获取绘图环境 02 var canvas=document.getElementById('canvas'); 03 var context=canvas.getContext('2d'); 04   05   06 //创建对象集合 (集合所有精灵) 07 var 

基于构建实时WEb应用的HTML5 WebSocket协议&lt;二&gt;

前面说了那么多的理论,我们来看下代码学习. WebSocketAPI简介 首先看一段简单的javascript代码,该代码调用了WebSockets的API. var ws = new WebSocket("ws://echo.websocket.org"); ws.onopen = function(){ws.send("Test!"); }; ws.onmessage = function(evt){console.log(evt.data);ws.close(

使用 HTML5 WebSocket 构建实时 Web 应用

作为下一代的 Web 标准,HTML5 拥有许多引人注目的新特性,如 Canvas.本地存储.多媒体编程接口.WebSocket 等等.这其中有"Web 的 TCP "之称的 WebSocket 格外吸引开发人员的注意.WebSocket 的出现使得浏览器提供对 Socket 的支持成为可能,从而在浏览器和服务器之间提供了一个基于 TCP 连接的双向通道.Web 开发人员可以非常方便地使用 WebSocket 构建实时 web 应用,开发人员的手中从此又多了一柄神兵利器.本文首先介绍

HTMl5/CSS3/Javascript 学习推荐资源

HTMl5/CSS3/Javascript 学习推荐资源 前端的定义应该是数据内容的展示,在国内大家都觉得前端只是HTML+CSS+Javascript,但是实际上与展示有关的都是前端,所以Ruby/Python/Nodejs/Java/ASP .NET只要和展示有关的部分都可以称之为前端.在这里由于篇幅的限制,我们只推荐与HTML+CSS+Javascript三者有关的前端技术 入门 w3school html5 简单HTML5的入门教程 w3school css3 简单的CSS3入门教程 J

【HTML5 WebSocket】WebSocket对象特性和方法

<HTML5 WebSocket权威指南>学习笔记&3 WebSocket方法的对象特性 1. WebSocket方法 a. send方法 send方法用于在WebSocket连接建立后,客户端向服务端发送消息.可分为发送两种消息,一种是普通文本信息,一种是二进制数据.需注意的是,send方法必须在连接建立以后才能使用,也就是在onopen里使用才不会出错. 发送普通消息 这个比较简单,在上一篇学习WebSocket事件时就用到了,只需要send(message)即可. 发送二进制数据

浅谈HTML5 WebSocket的机制

回顾上一章 在上一章<为什么我们需要HTML5 WebSocket>中,我简单的介绍了下WebSocket的前世今生.相信大家已对WebSocket有了初步的了解.那么今天我们继续深入学习WebSocket的机制. WebSocket机制 我们知道WebSocket是HTML5一种新的协议.它实现了浏览器与服务器全双工通信(不知道的可以看下全双工通信RS-422标准),能更好的节省服务器资源和带宽并达到实时通讯,它建立在TCP之上,同HTTP一样通过TCP来传输数据,但是它和HTTP最大不同是

初识html5 WebSocket

1.  WebSocket概念 WebSocket是HTML5开始提供的一种Client与Server间进行全双工(full-duplex)通讯的网络技术 双工(duplex),指二台通讯设备之间,允许有双向的资料传输 Client和Server通过WebSocket Protocol建立连接后,双方可以互传数据并且双方都可以关闭此连接 2. HTTP概念 HTTP Protocol是无状态协议的,Client和Server通过HTTP Protocol建立连接后,将采用"request-res