IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> WebSocket(简单体验版) -> 正文阅读

[网络协议]WebSocket(简单体验版)

WebSocket(简单体验版)

简介

Web Socket(套接字):就是通过一个长时连接实现与服务器全双工、双向的通信。

Web Socket使用的并不是HTTP协议而是自定义的Web Socket协议,所以如果我们使用Web Socket的时候,URL不再是http://https://,而是ws://wss://(但是,实际上是看红宝书才想着玩一下下,在开发中还没试过用这个来开发的)

主要特点:服务器可以主动向客户端推送信息,客户端也可以主动向服务器发送信息。

使用

实例化

要创建一个新的Web Socket,首先需要实例化一个WebSocket对象。

我们实例化WebSocket对象时,传的参数应该是一个绝对URL同源策略不适用于WebSocket

const socket = new WebSocket("ws://localhost:8088/mysocket");

image-20220529170446392

http请求会有跨域,但是WebSocket不会跨域

后端express

主要部分都注释了(需要安装 express-ws)

const express = require('express')
const expressWs = require('express-ws')

const app = express()

// 将WebSocket服务加到app里,简单来说就是让app添加了ws方法
expressWs(app)

// 建立WebSocket服务
app.ws('/mysocket', function (ws) {
  // ws:建立WebSocket的实例
    
  // 向客户端发送信息
  ws.send('你连接成功啦')
})

app.listen(8088, () => {
  console.log('ws://localhost:8088')
})

image-20220529172415750

如果连接上了,那么http状态码会是101,因为要切换成ws协议

绑定事件

如果我们,在实例化后就开始发送信息,那就会导致信息发不出,因为还没连接上。这时候我们就得了解一下什么时候能发,进而得了解一下WebSocket的相关事件。

  • open:在连接成功建立时触发
  • error:在连接发生错误时触发(此时已经不能再发信息了)
  • close:在连接关闭时触发(此时已经不能再发信息了)
  • message:收到消息后触发(收到的消息在事件对象中的data里)
const socket = new WebSocket("ws://localhost:8088/mysocket");
socket.onopen = function () {
    console.log("连接建立");
    socket.send('hello');
    // socket.close()
};
socket.onerror = function () {
    console.log("连接发生错误");
};
socket.onclose = function () {
    console.log("连接关闭");
};

socket.onmessage = function (e) {
    console.log(e)
}

image-20220529173743731

image-20220529174046932

模拟两人对话

上面已经说了,收到消息会触发message事件,所以我们可以在message事件里根据收到的信息发送对应的信息。

客户端:

const socket = new WebSocket("ws://localhost:8088/mysocket");
socket.onopen = function () {
    console.log("连接建立");
    socket.send('hello');
    // socket.close()
};
socket.onerror = function () {
    console.log("连接发生错误");
};
socket.onclose = function () {
    console.log("连接关闭");
};

socket.onmessage = function ({ data }) {
    if (data.includes('你好')) {
        socket.send('再见,服务端ddd')
    } else if (data.includes('再见')) {
        // 调用close()方法关闭WebSocket连接
        socket.close()
    } else {
        socket.send('你好,我是客户端ccc')
    }
}

服务器:

const express = require('express')
const expressWs = require('express-ws')

const app = express()

// 将WebSocket服务加到app里,简单来说就是让app添加了ws方法
expressWs(app)

// 建立WebSocket服务
app.ws('/mysocket', function (ws) {
  // ws:建立WebSocket的实例
  ws.send('你连接成功啦')

  ws.onmessage = function ({ data }) {
    if (data.includes('你好')) {
      ws.send('你好,我是服务器ddd')
    } else if (data.includes('再见')) {
      ws.send('再见,客户端ccc')
    }
  }
})

app.listen(8088, () => {
  console.log('ws://localhost:8088')
})

image-20220529175742257

注意:如果收发部分处理,需要注意一下,如果没有处理好,可能会出现循环卡住的情况。

比如,服务器和客户端的message事件回调都是:

socket.onmessage = function ({ data }) {
    socket.send('hello')
}

image-20220529180303794

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-06-29 19:26:03  更:2022-06-29 19:26:51 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年4日历 -2024/4/23 14:12:11-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码