vue3 ts4 封装 mqtt 同一连接订阅多主题

本文是对改良:vue3+ts 封装mqtt_你的微笑、暖暖的的博客-优快云博客近期在vue3的项目中使用到了mqtt,再次记录下,供大家学习。https://blog.youkuaiyun.com/wangyuiba1314/article/details/126307598

服务器采用,RabbitMQ3.9,开启rabbitmq_web_mqtt,部署方法参考http://t.csdn.cn/Xe6Vg

0.安装相关组件

mqtt:用于连接

npm i "mqtt"

uuid:用于确定客户端唯一(非必须)

npm i "vue-uuid"

1.新建Mqtt.ts

import type { MqttClient, OnMessageCallback } from 'mqtt';
import * as mqtt from 'mqtt/dist/mqtt.min.js';
import { uuid } from 'vue-uuid';

class MQTT {
  type: string; // 客户端分类(非必须)
  url: string; // mqtt地址
  client!: MqttClient;

  constructor(type: string) {
    this.type= type;
    this.url = 'ws://192.168.x.x:15675/ws';// ws方式必须ws结尾
  }

  //初始化mqtt
  init() {
    const options = {
      clean: true,
      clientId: this.type+ "_" + uuid.v1(), // 客户端分类唯一
      username: 'xxx',
      password: 'xxx',
      connectTimeout: 3000, // 超时时间
    };

    this.client = mqtt.connect(this.url, options);

    this.client.on('error', (error: any) => {
      console.log(this.url + "异常中断");
    });

    this.client.on('reconnect', (error: Error) => {
      console.log(this.url + "重新连接");
    });
  }

  //取消订阅
  unsubscribes(topic: string) {
    this.client.unsubscribe(topic, (error: Error) => {
      if (!error) {
        console.log(topic + '取消订阅成功');
      } else {
        console.log(topic + '取消订阅失败');
      }
    });
  }

  //连接
  link(topic: string) {
    this.client.on('connect', () => {
      this.client.subscribe(topic, (error: any) => {
        if (!error) {
          console.log(topic + '订阅成功');
        } else {
          console.log(topic + '订阅失败');
        }
      });
    });
  }

  //收到的消息
  get(callback: OnMessageCallback) {
    this.client.on('message', callback);
  }

  //结束链接
  over() {
    this.client.end();
  }
}
export default MQTT;

2.新建UseMqtt.ts

import MQTT from './Mqtt';
import type { OnMessageCallback } from 'mqtt';
import {
  ref,
  onUnmounted
} from 'vue';

export default function useMqtt() {
  const PublicMqtt = ref<MQTT | null>(null);
  const linkList = Array<string>(); // 长连接的列表

  const startMqtt = (type: string, callback: OnMessageCallback) => {
    PublicMqtt.value = new MQTT(type);//创建连接
    PublicMqtt.value.init();//初始化mqtt
    linkList.forEach((topic) => { PublicMqtt.value?.unsubscribes(topic); PublicMqtt.value?.link(topic) });//订阅主题
    getMessage(callback);
  };

  const addLink = (topic: string) => {
    if (!linkList.includes(topic)) { // 简单地去重
      linkList.push(topic);
      PublicMqtt.value?.link(topic);
    }
  }

  const Uint8ArrayToString = (fileData: Uint8Array) => {
    var dataString = "";
    for (var i = 0; i < fileData.length; i++) {
      dataString += String.fromCharCode(fileData[i]);
    }
    return dataString
  }

  const getMessage = (callback: Function) => {
    PublicMqtt.value?.get((t, m) => { callback(t, Uint8ArrayToString(m)); });
  };

  onUnmounted(() => {//页面销毁结束订阅
    linkList.forEach((topic) => { PublicMqtt.value?.unsubscribes(topic) });
    PublicMqtt.value?.over();
  });

  return {
    startMqtt,
    addLink
  };
}

3.使用vue

<script setup lang="ts">
  import UseMqtt from './UseMqtt';

  const {
    startMqtt,
    addLink
  } = UseMqtt();

 // 创建一个连接
 startMqtt("A", (topic, data) => {
    console.log(topic);
    console.log(data);
 });

 // 订阅多主题
 addLink('a001');
 addLink('a002');
</script>

Vue3封装 MQTT(Message Queuing Telemetry Transport)支持通常涉及以下几个步骤: 1. **安装依赖**:首先需要安装 MQTT 客户端库,如 `@nestjs/mqtt` 或者 `socket.io-client-mqtt` 等,取决于项目框架(如 NestJS 或 vanilla JavaScript)。 ```bash npm install @nestjs/mqtt socket.io-client-mqtt ``` 2. **创建MQTT连接**:在 Vue 组件或者服务中初始化 MQTT 连接。这通常需要提供服务器地址、端口和认证信息。 ```javascript import { createSocket } from &#39;socket.io-client-mqtt&#39;; const mqttClient = createSocket(&#39;mqtt://your-mqtt-server.com&#39;, { username: &#39;your_username&#39;, password: &#39;your_password&#39; }); ``` 3. **消息订阅与发布**:封装方法来处理 MQTT订阅(on()方法)和发布(publish()方法),使得它们在 Vue 层面上易于使用。 ```javascript methods: { subscribeToTopic(topic) { mqttClient.on(topic, (message) => { // 在这里处理接收到的消息 console.log(`Received message on ${topic}:`, message); }); }, sendMessage(topic, payload) { mqttClient.publish(topic, payload); } } ``` 4. **解耦组件**:为了保证组件的复用性和灵活性,可以在单独的服务或者模块里封装这些操作,并通过 Vuex 或者事件总线将状态和动作传递给视图层。 5. **错误处理**:别忘了添加适当的错误处理机制,比如连接失败、超时或断开时的重连等。 ```javascript methods: { connect() { mqttClient.connect().catch((error) => { // 处理连接错误 }); }, disconnect() { mqttClient.disconnect(); }, } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值