美文网首页牵线搭桥Web 前端开发 前端开发那些事
基于Socket.IO的客户端和服务端通信

基于Socket.IO的客户端和服务端通信

作者: 葶寳寳 | 来源:发表于2017-08-25 14:51 被阅读0次

Socket.IO是一个封装了 Websocket、基于NodeJavaScript 框架,包含 clientJavaScriptserverNode。为实时应用提供跨平台实时通信。其屏蔽了所有底层细节,让顶层调用非常简单。

接下来我们一起来搭建基于Socket.IO的服务端。

首先运行一下命令,生成一个package.json文件:

npm init -y

然后安装 express框架和socket.io

npm  install  express  --save
npm  install  socket.io  --save

等这些工作都做好之后,我们就可以编写node代码,来创建一个WebSocket服务器了:

//server.js

let express = require('express');
let app = new express();
let server = require('http').createServer(app);
let io = require('socket.io').listen(server);
//将 socket.io 绑定到服务器上,于是任何连接到该服务器的客户端都具备了实时通信功能。

server.listen(8000);

app.use(express.static(__dirname + '/'));

app.get('/', function (req, res) {
    res.sendfile(__dirname + '/index.html');
});

//服务器监听所有客户端,并返回该新连接对象
io.sockets.on('connection', function (socket) {
    socket.emit('name', {username: 'litingting ' + new Date()});
    socket.on('my other event', function (data) {
        console.log(data +  new Date());

    });
});

客户端实现:

//html文件
<script src="/socket.io/socket.io.js"></script>
<script>
let socket = io();
socket.on('name', function (data) {
    alert(data.username);
    socket.emit('my other event', { my: 'data' });
});
</script>

在浏览器打开localhost:8000/即可看到运行结果。
demo地址

服务器和客户端都有 emiton这两个函数,是socket.io的核心,通过emiton可以轻松地实现服务器与客户端之间的双向通信。

  • emit :用来发射一个事件或者说触发一个事件,第一个参数为事件名,第二个参数为要发送的数据,第三个参数为回调函数(一般省略,如需对方接受到信息后立即得到确认时,则需要用到回调函数)。

  • on:用来监听一个 emit 发射的事件,第一个参数为要监听的事件名,第二个参数为一个匿名函数用来接收对方发来的数据,该匿名函数的第一个参数为接收的数据,若有第二个参数,则为要返回的函数。

socket.io提供了三种默认的事件(客户端和服务器都有):connectmessagedisconnect 。当与对方建立连接后自动触发 connect 事件,当收到对方发来的数据后触发 message事件(通常为socket.send() 触发),当对方关闭连接后触发 disconnect事件。

此外,socket.io 还支持自定义事件

最后,需要注意的是,在服务器端区分以下三种情况:

  • socket.emit() :向建立该连接的客户端广播
  • socket.broadcast.emit():向除去建立该连接的客户端的所有客户端广播
  • io.sockets.emit():向所有客户端广播,等同于上面两个的和

参考资料:
第一章 socket.io 简介及使用
WebSocket 与 Socket.IO

相关文章

  • socket.io使用

    socket.io是基于Node.js 和 WebSocket协议的实时通信开源框架, 它包括客户端的Js和服务端...

  • TCP/UDP套接字通信

    一,基于TCP套接字通信 服务端 客户端 二,基于UDP套接字通信 服务端 客户端 - 执行如下(服务端无返回信息...

  • Socet.io和Socket.io-client开发

    关于实时聊天进行通信,这里选择使用服务端插件socket.io和客户端插件socket.io-client,分别在...

  • 【React.js 16】Socket.io实现实时软件

    Socket.io是基于websocket的库,可以帮助我们实现实时通讯软件。 安装 服务端: 客户端: 配合Ex...

  • Java学习5-socket通信(2)

    基于TCP协议的socket通信 目标:了解概念,通信模型,实现socket的步骤,服务端和客户端应该做些什么 什...

  • MySQL逻辑架构

    1.最上层是一些客户端和连接服务,包含本地sock通信和大多数基于客户端/服务端工具实现的类似于tcp/ip的通信...

  • websocket与spring结合

    一种客户端与服务端基于http的全双工通信方式解决了服务端往客户端数据推送的问题 客户端 必要条件: 明确webs...

  • 基于Netty实现服务端与客户端通信

    个人博客http://www.milovetingting.cn 基于Netty实现服务端与客户端通信 前言 本文...

  • day31socket的通信流程介绍

    socket的通信流程 TCP是基于链接的,必须先启动服务端,然后再启动客户端去链接服务端 # 服务端 impor...

  • websocket(1)

    socket.io简述 1、基本介绍 socket.io是基于websocket技术,实现实时通信功能的技术。 简...

网友评论

    本文标题:基于Socket.IO的客户端和服务端通信

    本文链接:https://www.haomeiwen.com/subject/wpikdxtx.html