文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么优雅的使用WebSocket

2023-06-30 12:25

关注

这篇“怎么优雅的使用WebSocket”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么优雅的使用WebSocket”文章吧。

简介

websocket是基于TCP的一种双向通信协议。在此之前,一直是采用轮询的方式进行双向通信,这种方式效率低下还非常浪费资源。为了解决这种问题,websocket应运而生。

特性

使用场景

具体实现

一、首先是服务端代码,这里我用的是nodejs。

我们先新建一个websocket.js文件

// 创建websocket服务const port = "8888"const ws = require('nodejs-websocket');const web_server = ws.createServer(function (conn) {  conn.on('text', function (text) {    console.log("发送的消息",text);    conn.sendText(`发送成功了,发送的消息为:${text}`)  });  conn.on('close', function (code, reason) {    console.log('关闭连接');  });  conn.on('error', function (code, reason) {    console.log('异常关闭');  });}).listen(port);exports.web_server = web_server

在app.js里面进行引入

const websocket = require("./websocket")

最后启动服务

node app

二、然后是客户端代码

① 在vue中使用

我们先在utils下新建一个websocket.js文件

let webSocket = null;let socketOpen = false;// 发送消息export const doSend = (message) => {  if (socketOpen) {    webSocket.send(message)  }}// 初始化websocketexport const contactSocket = () => {  if ("WebSocket" in window) {    webSocket = new WebSocket("ws://192.168.1.100:8888/");    webSocket.onopen = function () {      console.log("连接成功!");      socketOpen = true    };    webSocket.onmessage = function (evt) {      var received_msg = evt.data;      console.log("接受消息:" + received_msg);    };    webSocket.onclose = function () {      console.log("连接关闭!");    };  }}

页面引入文件

import { contactSocket, doSend }  from '@/utils/contactSocket'

具体使用实例

// 初始化websocketcontactSocket()// 发送消息内容setTimeout(() => {  doSend("向服务端发送的消息")}, 1000)

② 在uniapp中使用

我们先在utils文件夹下新建一个websocket.js文件

let socketOpen = false;// 发送消息function doSend(message) {    if (socketOpen) {        uni.sendSocketMessage({            data: message        });    } }// 初始化websocketfunction contactSocket() {    // 建立连接    uni.connectSocket({        url: 'ws://192.168.1.100:8888/'    });    // 连接错误    uni.onSocketError(function(res) {        console.log('WebSocket连接打开失败,请检查!');    });    // 打开了连接    uni.onSocketOpen(function() {        console.log('WebSocket连接已打开!');        socketOpen = true;    });    // 关闭连接    uni.onSocketClose(function(res) {        console.log('WebSocket 已关闭!');    });    // 接受消息    uni.onSocketMessage(function(res) {        console.log('收到服务器内容:' + res.data);    });}module.exports = {    doSend,    websocketInit}

页面引入文件

import { doSend, contactSocket } from '@/utils/websocket.js'

具体使用实例

// 初始化websocketcontactSocket()// 发送消息内容setTimeout(()=>{    doSend("向服务端发送的消息");},1000)

以上就是关于“怎么优雅的使用WebSocket”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯