ホームページ >バックエンド開発 >PHPチュートリアル >PHPとMQTTを利用したリアルタイム在庫管理・早期警報機能
PHP と MQTT を使用して、リアルタイムの在庫管理と早期警告機能を実現します
1. 背景の紹介
現代のビジネス運営において、在庫管理は非常に重要な部分です。正確な在庫情報は、企業が製品の数量と変化をリアルタイムで把握するのに役立ち、より正確な購買および販売の意思決定を可能にします。同時に、在庫警告機能は在庫不足を事前に予測し、企業が在庫切れなどの悪影響を回避するのに役立ちます。
2. テクノロジーの選択
この記事では、サーバー側プログラミング言語として PHP を使用し、それを MQTT プロトコルと組み合わせて、リアルタイムの在庫管理と早期警告機能を実現します。一般的に使用される Web 開発言語として、PHP は学習と使用が簡単で、MQTT プロトコルはモノのインターネットやモバイル アプリケーションのシナリオに適した軽量のメッセージング プロトコルです。
3. 在庫管理機能の実装
1. データベース設計
まず、inventoryという名前のデータベースを作成し、製品の在庫情報を格納するproductsという名前のデータテーブルを作成します。データ テーブルには次のフィールドが含まれます:
2. ページのデザインと開発
在庫情報を表示するために、index.php という名前のファイルを作成します。このファイルには、すべての製品の名前と数量をリストし、ユーザーが製品名と数量を入力するためのフォームを提供できます。
3. データベース接続とデータ読み取り
PHP ファイルでは、データベースに接続し、データベースから商品在庫情報を読み取る必要があります。以下は、データベースに接続してデータを読み取るコード例です:
<?php $servername = "localhost"; $username = "username"; $password = "password"; $dbname = "inventory"; // 创建连接 $conn = new mysqli($servername, $username, $password, $dbname); // 检查连接是否成功 if ($conn->connect_error) { die("连接失败: " . $conn->connect_error); } // 从数据库中读取产品的库存信息 $sql = "SELECT id, name, quantity FROM products"; $result = $conn->query($sql); if ($result->num_rows > 0) { echo "<table>"; echo "<tr><th>产品ID</th><th>产品名称</th><th>产品数量</th></tr>"; while($row = $result->fetch_assoc()) { echo "<tr><td>".$row["id"]."</td><td>".$row["name"]."</td><td>".$row["quantity"]."</td></tr>"; } echo "</table>"; } else { echo "暂无产品信息"; } $conn->close(); ?>
IV. 在庫早期警告機能の実装
1. 在庫早期警告しきい値を設定します
在庫を実装するには早期警告機能では、在庫の早期警告しきい値を設定する必要があります。製品の在庫がこのしきい値を下回ると、システムは早期警告メッセージを発行します。
2. MQTT メッセージの送信
PHP ファイルでは、MQTT プロトコルを使用して警告メッセージを送信できます。以下は、MQTT メッセージを送信するコード例です:
<?php require("phpMQTT.php"); $server = 'localhost'; //MQTT服务器地址 $port = 1883; //MQTT服务器端口号 $username = 'username'; //MQTT用户名 $password = 'password'; //MQTT密码 $mqtt = new phpMQTT($server, $port, "PHP MQTT Client"); if (!$mqtt->connect(true, NULL, $username, $password)) { exit(1); } $topic = 'inventory/alert'; //MQTT主题 $message = '产品A库存不足,请及时补货!'; //预警消息 // 发布MQTT消息 $mqtt->publish($topic, $message, 0, false); $mqtt->close(); ?>
3. MQTT メッセージのサブスクライブ
MQTT アラート メッセージを受信するには、別の PHP ファイルとプロセスで対応する MQTT トピックをサブスクライブする必要があります。受信したメッセージ。 MQTT メッセージをサブスクライブするコード例を以下に示します。
<?php require("phpMQTT.php"); $server = 'localhost'; //MQTT服务器地址 $port = 1883; //MQTT服务器端口号 $username = 'username'; //MQTT用户名 $password = 'password'; //MQTT密码 $mqtt = new phpMQTT($server, $port, "PHP MQTT Client"); if (!$mqtt->connect(true, NULL, $username, $password)) { exit(1); } $topic = 'inventory/alert'; //MQTT主题 // 定义接收消息的回调函数 function messageReceived($topic, $message) { echo "接收到预警消息:[{$topic}] {$message}<br/>"; } // 订阅MQTT主题并设置接收消息的回调函数 $mqtt->subscribe($topic, function($topic, $message){ messageReceived($topic, $message); }, 0); while ($mqtt->proc()) { } $mqtt->close(); ?>
5. まとめ
PHP と MQTT プロトコルを使用することで、リアルタイムの在庫管理と早期警告機能を実現しました。 MQTT プロトコルを使用すると、リアルタイム メッセージのパブリッシュとサブスクライブを行うことができ、在庫が警告しきい値を下回ったときに警告メッセージをタイムリーに送信できます。これにより、企業の在庫管理の効率が向上し、在庫切れなどの問題を回避できます。同時に、データベースの設計と運用により、在庫情報の正確な記録と照会を実現できます。実際のアプリケーションでは、より具体的なビジネス シナリオを満たすために、特定のニーズに応じてコードを変更および最適化できます。
以上がPHPとMQTTを利用したリアルタイム在庫管理・早期警報機能の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。