WebSocket 和 Socket.IO

这篇具有很好参考价值的文章主要介绍了WebSocket 和 Socket.IO。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

WebSocket

WebSocket 是一种网络通信协议,它提供了全双工(full-duplex)通信通道,允许服务器和客户端之间进行双向通信。这种通信方式比传统的 HTTP 请求/响应模式更高效,因为它减少了网络延迟,并且只需要一个 TCP 连接就可以进行双向通信。

WebSocket 的工作流程如下:

    1. 客户端发送一个 HTTP 请求到服务器,这个请求包含一个 "Upgrade: websocket" 头部,表示客户端希望升级到 WebSocket 协议。

    2. 如果服务器支持 WebSocket 协议,它会返回一个包含 "101 Switching Protocols" 状态码的 HTTP 响应,表示服务器同意升级到 WebSocket 协议。

    3. 一旦协议升级完成,客户端和服务器就可以在同一个 TCP 连接上进行双向通信。

以下是一个使用 Node.js 的 WebSocket 服务器的示例:

const WebSocket = require('ws');
const wss = new WebSocket.Server({ port: 8080 });
wss.on('connection', ws => {
	ws.on('message', message => {
		console.log('received: %s', message);
	});
	ws.send('Hello! I am a WebSocket server.');
});

在这个示例中,服务器监听 8080 端口的 WebSocket 连接。当有新的连接建立时,服务器会发送一条消息给客户端。当服务器接收到客户端的消息时,它会打印这条消息。

WebSocket 协议是 HTML5 的一部分,大多数现代浏览器都支持 WebSocket 协议。以下是一个在浏览器中使用 WebSocket 的示例:

const ws = new WebSocket('ws://localhost:8080');
ws.onopen = () => {
	ws.send('Hello! I am a WebSocket client.');
};
ws.onmessage = event => {
	console.log('received: %s', event.data);
};

在这个示例中,浏览器创建一个新的 WebSocket 连接到服务器。当连接建立时,浏览器会发送一条消息给服务器。当浏览器接收到服务器的消息时,它会打印这条消息。

WebSocket 协议非常适合实时应用,如聊天应用、多人在线游戏、实时股票报价等。

Socket.IO 

Socket.IO 是一个基于 Node.js 的库,它提供了实时、双向和基于事件的通信能力。它主要由两部分组成:在服务器端的 Node.js 库和在客户端的 JavaScript 库。Socket.IO 不仅支持 WebSocket,还支持许多其他的传输机制,如 AJAX 长轮询、AJAX 多路复用等,以实现实时通信。

Socket.IO 的主要特点包括:

    1. 实时分析:你可以在服务器端推送实时事件到客户端。

    2. 二进制支持:你可以发送图片、视频或者任何二进制数据。

    3. 文档同步:当一个文档更新时,你可以将更新的内容实时推送到所有的客户端。

    4. 实时聊天:你可以创建一个实时聊天应用。

以下是一个使用 Socket.IO 的示例:

const express = require('express');
const http = require('http');
const socketIo = require('socket.io');

const app = express();
const server = http.createServer(app);
const io = socketIo(server);

io.on('connection', (socket) => {
	console.log('a user connected');

	socket.on('disconnect', () => {
		console.log('user disconnected');
	});

	socket.on('chat message', (msg) => {
		io.emit('chat message', msg);
	});
});

server.listen(3000, () => {
	console.log('listening on *:3000');
});

在这个示例中,服务器监听 3000 端口的连接。当有新的连接建立时,服务器会打印一条消息。当连接断开时,服务器也会打印一条消息。当服务器接收到 'chat message' 事件时,它会将这个消息广播给所有的客户端。

在客户端,你可以使用 Socket.IO 的客户端库来连接到服务器,并发送和接收事件。以下是一个在浏览器中使用 Socket.IO 的示例:

const socket = io();

$('form').submit(function(e) {
	e.preventDefault(); // prevents page reloading
	socket.emit('chat message', $('#m').val());
	$('#m').val('');
	return false;
});

socket.on('chat message', function(msg) {
	$('#messages').append($('<li>').text(msg));
});

在这个示例中,当用户提交表单时,浏览器会发送一个 'chat message' 事件到服务器,并清空输入框。当浏览器接收到 'chat message' 事件时,它会将这个消息添加到消息列表中。文章来源地址https://www.toymoban.com/news/detail-510797.html

到了这里,关于WebSocket 和 Socket.IO的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 网络通信(Socket/TCP/UDP)

    Socket(又叫套接字)是通信的基石,是支持TCP/IP协议的网络通信的基本操作单元。它是网络通信过程中端点的抽象表示,包含进行网络通信必须的五种信息:连接协议,客户端的IP地址,客户端的端口,服务器的IP地址,服务器的端口。 一个Socket是一对IP地址和端口。 Socket可以看

    2024年01月22日
    浏览(56)
  • 【网络】socket——预备知识 | 套接字 | UDP网络通信

    🐱作者:一只大喵咪1201 🐱专栏:《网络》 🔥格言: 你只管努力,剩下的交给时间! 在前面本喵对网络的整体轮廓做了一个大概的介绍,比如分层,协议等等内容,现在我们直接进入socket(套接字)编程,先来感受到网络编程。 我们知道,在网络通信中,存在两套地址,一

    2024年02月13日
    浏览(54)
  • 网络编程之简单socket通信

    Socket,又叫套接字,是在应用层和传输层的一个抽象层。它把TCP/IP层复杂的操作抽象为几个简单的接口供应用层调用以实现进程在网络中通信。  socket分为流socket和数据报socket,分别基于tcp和udp实现。 SOCK_STREAM 有以下几个特征: 数据在传输过程中不会消失; 数据是按照顺序

    2024年02月01日
    浏览(49)
  • 基于python的socket网络通信【1】

    学习了大佬的知识,简单记一些笔记 https://www.jianshu.com/p/066d99da7cbd http://c.biancheng.net/view/2351.html 在计算机通信领域,socket 被翻译为“套接字”,它是计算机之间进行通信的一种约定或一种方式。通过 socket 这种约定,一台计算机可以接收其他计算机的数据,也可以向其他计算

    2024年02月02日
    浏览(43)
  • 如何实现前端实时通信(WebSocket、Socket.io等)?

    聚沙成塔·每天进步一点点 前端入门之旅:探索Web开发的奇妙世界 欢迎来到前端入门之旅!感兴趣的可以订阅本专栏哦!这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们量身打造的。无论你是完全的新手还是有一些基础的开发者,这里都将为你提供一个系统而

    2024年01月22日
    浏览(48)
  • 【网络通信】socket编程——TCP套接字

    TCP依旧使用代码来熟悉对应的套接字,很多接口都是在udp中使用过的 所以就不会单独把他们拿出来作为标题了,只会把第一次出现的接口作为标题 通过TCP的套接字 ,来把数据交付给对方的应用层,完成双方进程的通信 在 tcpServer.hpp 中,创建一个命名空间 yzq 用于封装 在命名

    2024年02月13日
    浏览(51)
  • 【Unity】Socket网络通信(TCP) - 最基础的客户端通信流程

    这篇文章主要内容是客户端与服务器通信的内容,服务端代码可以看我的这一篇文章【Unity】Socket网络通信(TCP) - 最基础的C#服务端通信流程 客户端与服务器的整个流程比较相似,客户端会更加简单一些: 创建socket 连接服务器 收发消息 释放socket,关闭连接 和服务端创建

    2024年02月03日
    浏览(47)
  • C++网络编程(一)本地socket通信

    本次内容简单描述C++网络通信中,采用socket连接客户端与服务器端的方法,以及过程中所涉及的函数概要与部分函数使用细节。记录本人C++网络学习的过程。 socket,即“插座”,在网络中译作中文“套接字”,应用于计算机网络建立起数据连接。基于TCP/IP协议进行通信,将本地的

    2024年02月15日
    浏览(45)
  • 【Unity】Socket网络通信(TCP) - 最基础的C#服务端通信流程

    我这里新建了一个C#控制台项目来写服务端代码。 下面是基于C# Socket的最基础服务端通信流程: 创建服务端Socket对象 绑定IP地址和端口 设置最大监听客户端数量 等待客户端连接 收发消息 释放连接 基于上面流程就能实现一个最简单并且能和客户端通信的服务器程序,每个步

    2023年04月16日
    浏览(64)
  • Java网络编程-Socket实现数据通信

    本文主要是为下一篇Websockt做铺垫,大家了解socket的一些实现。 网络编程是指利用计算机网络进行程序设计、开发的技术。网络编程主要包含三个要素,分别是: IP地址和端口号 传输协议 Socket 在计算机网络中,每台计算机都有一个IP地址,用于唯一标识该计算机在网络中的

    2024年02月10日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包