リアルタイムデータを取得してモバイルアプリに表示する必要があるため、インスタントメッセージングに MQTT を使用することを考えました。 以下は、uniapp に MQTT を導入する全体のプロセスです。 1. uniappプラグインマーケットのリファレンスプラグインhttps://ext.dcloud.net.cn/plugin?id=854 2. 具体的な導入プロセス1. mqttとuuidをインストールするコマンドラインを実行して、uniapp プロジェクトのルート ディレクトリにそれぞれ mqtt と uuid をインストールします。uuid は後で mqtt の clientId を生成するために使用されるため、ここでは一緒にインストールされます。 [email protected] をインストールします npm インストール uuid 追伸 ①ここで私がインストールしたmqttのバージョンは、uniappが提供しているプラグインと同じです。最新バージョンもインストールしようとしましたが、エラーが報告されます、うーん…… ②pakage.jsonがない場合、インストール時にエラーが表示されますが、インストールおよび使用には影響ありません。もっと便利にしたい場合は、プロジェクトのルート ディレクトリに pakage.json ファイルを追加し、次のコンテンツを追加できます。 { "名前": ""、 "バージョン": "1.0.0", "説明": ""、 "著者": ""、 「ライセンス」: 「MIT」、 「依存関係」: { "mqtt": "^3.0.0", "UUID": "^8.3.0" }, "devDependencies": {}, 「スクリプト」: {} } 2. このページではmqttを紹介し、①mqtt接続設定は/utils/mqtt.jsに配置され、グローバルに利用可能です。 export const MQTT_IP = '192.168.9.128:8083/mqtt' //mqtt アドレス ポート const MQTT_USERNAME = 'public' //mqtt ユーザー名 const MQTT_PASSWORD = 'public' //パスワード export const MQTT_OPTIONS = { 接続タイムアウト: 5000、 クライアントID: ''、 ユーザー名: MQTT_USERNAME、 パスワード: MQTT_PASSWORD、 クリーン: 偽 } ②vueページ参照mqtt MQTT の clientId は、異なるページが異なるトピックをサブスクライブするときにデータが固定されないように、uuid を使用して一意の識別コードを生成し ます。 <スクリプト> 'uuid' から { v4 } をインポートします。 輸入 { 、 MQTT_オプション } '@/utils/mqtt.js' から; var mqtt = require('mqtt/dist/mqtt.js') varクライアント エクスポートデフォルト{ データ() { 戻る { topic: '' // 購読するトピック} }, マウント() {this.connect() //接続}, メソッド: { 接続する() { MQTT_OPTIONS.クライアントID = v4() var that = これ // #ifdef H5 クライアント = mqtt.connect('ws://' + MQTT_IP, MQTT_OPTIONS) // #終了 // #ifdef MP-WEIXIN||APP-PLUS クライアント = mqtt.connect('wx://' + MQTT_IP, MQTT_OPTIONS) // #終了 クライアント.on('接続', 関数() { console.log('接続成功') client.subscribe(that.topic, function(err) { もしエラーが起きたら console.log('サブスクリプションが成功しました') } }) }).on('再接続', 関数(エラー) { console.log('再接続中...', that.topic) }).on('エラー', 関数(エラー) { console.log('接続に失敗しました...', error) }).on('end', 関数() { console.log('接続が切断されました') }).on('メッセージ', 関数(トピック, メッセージ) { console.log('プッシュ情報を受信:', message.toString()) }) } } } </スクリプト> 3. 運用結果データはリアルタイムで変化します。 以上が、uniapp で MQTT を使用する方法の共有です。 以上が、uniapp プロジェクトにおける MQTT の使用方法の詳細です。uniapp の MQTT の使用に関する詳細については、123WORDPRESS.COM 内の他の関連記事にも注目してください。 以下もご興味があるかもしれません:
|
<<: Linux環境にRedisをデプロイし、Dockerにインストールする方法
>>: MySQL エラー コード 1862 の解決方法: パスワードの有効期限が切れています
この記事では、例を使用して、MySQL 外部キーの 3 つの関係について説明します。ご参考までに、詳...
目次操作方法操作プロセス既存のテーブルにパーティション テーブルを作成し、データを新しいテーブルに移...
デモコマンドをカスタマイズするVue カスタム ディレクティブの構文は次のとおりです。 Vue.di...
この記事の例では、参考のために航空機戦争ゲームを実装するためのJSの具体的なコードを共有しています。...
問題の原因:スレーブサーバーがクローンマスターサーバーである場合、server-uuidの値は同じで...
目次1. 三項演算子の判定2. 動的に設定されるクラス3. 方法判定4. 配列バインディング5. e...
目次1. コンテナサービスの更新とDockerコンサルの検出1. サービス登録と検出とは何ですか? ...
目次必要とする実装コードデータベース数日前、友人からこれを書くのを手伝ってほしいと頼まれました。ただ...
目次1. MySQLデータのバックアップ1.1. データをバックアップするためのmysqldumpコ...
目次スケルトンスクリーンの使用Vueアーキテクチャスケルトンスクリーンアイデアの概要抽象コンポーネン...
目次テーブルの目的例えばテーブル分割戦略すでにオンラインになっている実行中のテーブルはどうすればよい...
最近、element-ui を統合したプロジェクトで vuethink を使用しました。以前は bo...
この記事では、マウスを動かしたときにセカンダリ メニュー バーを実装するために HTML+CSS を...
NATこのようにして、仮想マシンのネットワーク カードはホストの VMnet8 に接続されます。この...
1. InnoDBストレージエンジンを使用する必要がありますCPU と IO のパフォーマンスが向上...