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 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> js websocket代码 -> 正文阅读

[网络协议]js websocket代码

/**
 * 使用方法 import Socket from './websocket/ws'
 * this.wbSocket = new Socket(options)
 * this.wbSocket.onmessage((data) => {})
*/


import { Heart } from './heart.js'
import $config from '@/config';

export default class Socket extends Heart {
  constructor(ops) {
    super()

    this.RECONNECT_TIMER = null // 重连计时器

    this.RECONNECT_COUNT = 10 // 变量保存,防止丢失

    this.OPTIONS = {
      url: null, // 链接地址
      heartTime: 5000, // 心跳时间间隔
      heartMsg: 'ping', // 心跳信息,默认是‘ping’
      isReconnect: true, // 是否自动重连
      isRestory: true, // 是否销毁
      reconnectTime: 5000, // 重连时间间隔
      reconnectCount: 5, // 重连次数, -1则不限制
      openCb: null, // 链接成功回调
      closeCb: null, // 关闭的回调
      messageCb: null, // 消息的回调
      errorCb: null // 错误的回调
    }

    Object.assign(this.OPTIONS, ops)
    this.create()
  }

  // 建立链接
  create() {
    window.WebSocket = window.WebSocket || window.MozWebSocket;
    if(!window.WebSocket) {
      new Error('当前浏览器不支持,无法使用')
      return;
    }
    if(!this.OPTIONS.url){
      new Error('链接地址不存在,无法建立ws通道')
    }
    delete this.ws
    this.ws = new WebSocket(`ws://${$config.WS_API()}${this.OPTIONS.url}`)
    this.onopen()
    this.onclose()
    this.onmessage()
  }

  // open事件
  /**
   * 自定义链接成功事件
   * 如果callback存在,调callback,不存在调用OPTIONS中的回调
   * @param {Function} callback
  */
  onopen (callback) {
    this.ws.onopen = () => {
      clearTimeout(this.RECONNECT_TIMER) // 清除重连定时器
      this.OPTIONS.reconnectCount = this.RECONNECT_COUNT // 计时器重置
      // 建立心跳机制
      super.reset().start(() => {
        this.send(this.OPTIONS.heartMsg)
      })
      if (typeof callback === 'function') {
        callback(event)
      } else {
        ( typeof this.OPTIONS.openCb === 'function' ) && this.OPTIONS.openCb(event)
      }
    }
  }

  /**
   * 自定义关闭事件
   * 如果callback存在,调callback,不存在调用OPTIONS中的回调
   * @param {Function} callback
  */

  onclose (callback) {
    this.ws.onclose = (event) => {
      super.reset()
      !this.OPTIONS.isRestory && this.onreconnect() // 如果不是正常销毁的通道,就立即重连
      if (typeof callback == 'function') {
        callback(event)
      } else {
        ( typeof this.OPTIONS.openCb === 'function' ) && this.OPTIONS.closeCb(event)
      }
    }
  }

  /**
   * 自定义错误事件
   * 如果callback存在,调用callback,不存在调用OPTIONS中的回调
   * @param {Function} callback 回调函数
  */
  onerror (callback) {
    this.ws.onerror = (event) => {
      if (typeof callback === 'function') {
        callback(event)
      } else {
        (typeof this.OPTIONS.errorCb === 'function') && this.OPTIONS.errorCb(event)
      }
    }
  }

  /**
   * 自定义监听事件
   * 如果callback存在,调用callback,不存在调用OPTIONS中的回调
   * @param {Function} callback 回调函数
  */
  onmessage (callback) {
    this.ws.onmessage = (event) => {
      // 收到任何消息,重新开始倒计时心跳检测
      super.reset().start(() => {
        this.send(this.OPTIONS.heartMsg)
      })
      if (typeof callback === 'function') {
        callback(event.data)
      } else {
        (typeof this.OPTIONS.messageCb === 'function') && this.OPTIONS.messageCb(event.data)
      }
    }
  }

  /**
   * 自定义发送消息事件
   * 如果callback存在,调用callback,不存在调用OPTIONS中的回调
   * @param {Function} callback 回调函数
  */
  send (data) {
    if (this.ws.readyState !== this.ws.OPEN) {
      new Error('没有连接到服务器,无法推送')
      return
    }
    this.ws.send(data)
  }

  /**
   * 链接事件
  */
  onreconnect () {
    if (this.OPTIONS.reconnectCount > 0 || this.OPTIONS.reconnectCount === -1) {
      this.RECONNECT_TIMER = setTimeout( () => {
        this.create()
        if (this.OPTIONS.reconnectCount !== -1) {
          this.OPTIONS.reconnectCount --
        }
      }, this.OPTIONS.reconnectTime)
    }  else { 
      clearTimeout(this.RECONNECT_TIMER)
      this.OPTIONS.reconnectCount = this.RECONNECT_COUNT
    }   
  }


  /**
   * 链接事件
  */
  destroy () {
    super.reset()
    clearTimeout(this.RECONNECT_TIMER) // 清除重连定时器
    this.OPTIONS.isRestory = true
    this.ws.close()
  }
}

heart文件:

/**
 *建立心跳基类
*/

export class Heart {


  constructor() {
    this.timeout = 5000
    this.HEART_TIMEOUT = null // 心跳计时器
    this.SERVER_HEART_TIMEOUT = null // 心跳计时器
  }

  // 重置
  reset() {
    clearTimeout(this.HEART_TIMEOUT)
    clearTimeout(this.SERVER_HEART_TIMEOUT)
    return this
  }

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

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/2 2:50:56-

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