Vue でインスタント通信を実現するために MQTT サーバーを使用する手順を記録します。

Vue でインスタント通信を実現するために MQTT サーバーを使用する手順を記録します。

MQTT プロトコル

MQTT (Message Queuing Telemetry Transport) は、IBM が開発したインスタント メッセージング プロトコルであり、モノのインターネットの重要な部分になる可能性があります。このプロトコルはすべてのプラットフォームをサポートしており、インターネットに接続されたほぼすべてのオブジェクトを外部に接続できます。センサーやアクチュエータの通信プロトコルとして使用されます(Twitter 経由で家をインターネットに接続するなど)。

MQTT は、最小限のコードと帯域幅でリモート デバイスに接続できる、軽量のブローカー ベースのパブリッシュ/サブスクライブ メッセージング プロトコルです。たとえば、衛星やプロキシ接続、ダイヤルアップやヘルスケア プロバイダー接続、一部の自動化デバイスや小型デバイスなどです。また、サイズが小さく、省電力で、プロトコル オーバーヘッドが低く、1 つまたは複数の受信者に情報を効率的に送信できるため、モバイル アプリケーション デバイスにも適しています。

VueはMQTTサーバーを使用して即時通信を実現します

ほとんどのプロジェクトでは、フロントエンドとバックエンドのやり取りは、フロントエンドがバックエンド インターフェイスを要求し、データを取得した後に処理するだけです。以前、私が取り組んでいたプロジェクトでは、MQTT を使用する必要がありました。使用してみると、魔法のようでした。データをリアルタイムで取得するには、サブスクライブするだけで済みます。さっそく、手順を説明します。

1. vueプロジェクトにmqtt.jsをインストールする

npm インストール mqtt --save

2. プロジェクトのmain.jsまたは必要なvueページで参照します。

'mqtt' から mqtt をインポートします

3. 後で使用するために、vueページのデータにクライアントオブジェクトを定義します。

クライアント: {}

さて、次のステップが重要なポイントです。まず、MQTT に接続する必要があります。MQTT に接続するためのメソッドにはコールバック関数があります。次に、接続が成功した後のコールバックにサブスクリプション メソッドを記述して、エラーが発生しないようにします。これがコードです。

4. MQTTに接続してサブスクライブする

  //サーバーに接続する connect() {
      オプション = {
        ユーザー名: "xxx",
        パスワード: "xxxx",
        cleanSession: false、
        キープアライブ:60,
        クライアントID: 'mqttjs_' + Math.random().toString(16).substr(2, 8),
        接続タイムアウト: 4000
      }
      this.client = mqtt.connect('ws://192.168.xxx.xx:8083/mqtt',オプション);
      this.client.on("接続", (e)=>{
        console.log("サーバーに正常に接続しました:",e);
        // 'top/#'、'three/#'、'#' という名前の 3 つのトピックをサブスクライブします。this.client.subscribe(['top/#', 'three/#', '#'], { qos: 1 }, (err)=> {
          もしエラーが起きたら
            console.log("サブスクリプションが成功しました");
            // トピック「pubtop」に「hello, this is a nice day!」という内容のメッセージを公開します。this.publish("pubtop", 'hello, this is a nice day!')
          } それ以外 {
            console.log('メッセージのサブスクリプションに失敗しました!')
          }
        });
      });
      //再接続 this.reconnect()
      //接続が切断されましたか? this.mqttError()
      //情報をリッスンする this.getMessage()
    }

5. メッセージ公開方法

    //メッセージを公開 @topic subject @message コンテンツを公開 publish(topic,message) {
      クライアントが接続されている場合
        console.log('クライアントが接続されていません')
        戻る
      }
      this.client.publish(トピック、メッセージ、{qos: 1}、(err) => {
        もしエラーが起きたら
          console.log('件名は' + トピック + "正常に公開されました")
        }
      })
    }

6. 上記の3つのトピックを聞いて情報を受け取る

    //受信したメッセージをリッスンする getMessage() {
      this.client.on("メッセージ", (トピック, メッセージ) => {
        if(メッセージ) {
          console.log('受信元', topic, '情報', message.toString())
          定数 res = JSON.parse(message.toString())
          //コンソール.log(res, 'res')
          スイッチ(トピック) {
             ケース 'top/#' :
               this.msg = レス
               壊す;
             ケース 'three/#' :
               this.msg = レス
               壊す;
             ケース 'three/#' :
               this.msg = レス
               壊す;
             デフォルト:
               戻る
               this.msg = レス
           }
           this.msg = メッセージ
        }
      });
    },

7. サーバー接続が失敗していないか確認する

    //サーバー接続が失敗したかどうかを監視 mqttError() {
      this.client.on('エラー',(エラー) => {
        console.log('接続に失敗しました:',error)
        this.client.end()
      })
    },

8. 購読解除

    // 購読解除 unsubscribe() {
      this.client.unsubscribe(this.mtopic, (エラー)=> {
        console.log('トピックは' + this.mtopic + '購読解除に成功しました', error)
      })
    },

9. 切断する

    //切断 unconnect() {
      this.client.end()
      this.client = null
      console.log('サーバーが切断されました!')
    },

10. サーバーの再接続を待機する

    //サーバーの再接続を待機する reconnect() {
      this.client.on('再接続', (エラー) => {
          console.log('再接続中:', エラー)
      });
    },

要約する

これで、vue で MQTT サーバーを使用してインスタント メッセージングを実現する方法に関するこの記事は終了です。vue で MQTT インスタント メッセージングを使用する方法に関するより関連性の高いコンテンツについては、123WORDPRESS.COM で以前の記事を検索するか、次の関連記事を引き続き参照してください。今後も 123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • Vue は stompjs を使用して MQTT メッセージ プッシュ通知を実装します

<<:  MySQLカスケードレプリケーションの実装方法の例

>>:  MycliはMySQLコマンドライン愛好家にとって必須のツールです

推薦する

JavaScriptのアロー関数の特徴と通常の関数との違い

目次1. 矢印関数の使用1. 通常関数から矢印関数へ2. 中括弧を省略してリターンする3. 括弧を省...

MySQLプロセス関数の一般的な使用例の分析

この記事では、例を使用して MySQL プロセス関数の一般的な使用方法を説明します。ご参考までに、詳...

Linux での grep コマンドの使い方の詳細な説明

Linux grep コマンドLinux の grep コマンドは、ファイル内の条件を満たす文字列を...

Vue はグラフィック検証コードログインを実装します

この記事では、グラフィック認証コードログインを実装するためのVueの具体的なコードを参考までに紹介し...

JavaScript の useRef と useState の紹介

目次1. useStateフック2. useRefフック3. useRef と useState 4...

Ubuntu は、Mysql+Keepalived の高可用性実装 (デュアルアクティブ ホットスタンバイ) を構築します。

Mysql5.5 デュアルマシン ホットスタンバイ実装 2つのMySQLをインストールするMySQ...

Linux で binlog ファイルの作成時間を表示するコマンド

目次背景分析する方法背景MySQL は 26 日の 16:23:49 に大量のスロー クエリを生成し...

海外のウェブページのカラーマッチング事例20選共有

この記事では、優れた Web ページのカラー マッチングの事例を 20 件集めて紹介します。これらの...

nginx の 2 つのモジュールの proxy_pass の違い

1. 1.ngx_stream_proxy_moduleモジュールのproxy_passディレクティ...

要素テーブルの多層ネスト表示の実践

複数の注文を含むリストが必要です。各注文は一意にすることも、複数の注文を結合することもできます。各注...

MySQL テーブルスペースの断片化の概念と関連する問題の解決策

目次背景表領域の断片化とは何ですか?表領域の断片化を確認する方法表スペースの断片化問題を解決する方法...

無料のパブリック STUN サーバー

無料のパブリック STUN サーバーSIP 端末がプライベート IP アドレスを使用する場合、スタン...

標準的なHTMLの書き方は、Dreamweaverによって自動的に生成されるものとは異なります。

コードをコピーコードは次のとおりです。 <!--doctype はドキュメント タイプ htm...