关于flutter与django建立mqtt的研究

1. 使用mosquitto

这是一个mqtt服务器,用于广播数据

安装过程省略(有很多教程),安装完成后,可以在终端输入mosquitto,接下来就可以模拟这个一对多的发布者订阅模式了

订阅(topic1是订阅的主题,也可以是别的):mosquitto_sub -v -t topic1

发布:mosquitto_pub -t topic1 -m 消息内容

如下,是一个模拟过程:

首先,打开三个终端,这三个终端都输入"mosquitto_sub -v -t t1"表示这三个终端都订阅了这个主题:(图片放错啦,请将下面的topic1换成t1)

接着,再来一个终端,输入

bash 复制代码
mosquitto_pub -t t1 -m "Hello, MQTT!"

消息内容,去发布消息(接着这三个订阅这个主题的终端都可以接受到这个消息):

2. mosquitto设置局域网可访问

在mosquitto的安装目录,如"C:\Program Files\mosquitto"下,找到"mosquitto.conf"文件,插入两行:(分别表示端口和局域网可访问)

接下来,我们换一种方式去使用mosquitto,在"C:\Program Files\mosquitto"下打开终端,输入:

bash 复制代码
mosquitto -c mosquitto.conf -v

这就表示按照配置去运行mosquitto服务器啦,接着我们来换一种方式模拟,开几个终端,输入如下:(实际上还应该输入-h mosquitto服务器的ip,但是现在是在一台电脑上的操作,就省事儿了)

接着我们再起一个终端,用于发布消息,如下:(输入:"mosquitto_pub -t t334 -p 8889 -m 这是给t334QQQQQQQ的消息!"等消息)

3. flutter使用mqtt

话不多说,安装:

javascript 复制代码
mqtt_client: ^10.3.0

使用:(运行,服务端会检测到)

【注】:如果是真机有问题(貌似需要配置ssl)目前只能电脑本地模拟器运行,等评论区大佬解决😂(等作者解决估计要很久)

Dart 复制代码
import 'package:flutter/material.dart';
import 'package:mqtt_client/mqtt_client.dart';
import 'package:mqtt_client/mqtt_server_client.dart';

main(){runApp(const MaterialApp(home: H(),));}
class H extends StatefulWidget {
  const H({super.key});

  @override
  State<H> createState() => _HState();
}

class _HState extends State<H> {
  final client = MqttServerClient.withPort('192.168.101.21', "small_sun", 8889);
  String _resStr = "";
  Future<void> initClient() async {

    client.logging(on: false); //是否开启日志,这里就不看看日志了
    client.keepAlivePeriod = 20; //设置超时时间
    try {
      // await client.connect(username, password); //开始连接
      await client.connect();// 一般需要输入密码,如:client.connect(username, password);
      print('mqtt连接啦');
    } catch (e) {
      client.disconnect();
    }
    if (client.connectionStatus?.state == MqttConnectionState.connected) {
    } else {
      client.disconnect();
    }

    client.subscribe("t1", MqttQos.atMostOnce);// 订阅的主题1
    client.subscribe("t2", MqttQos.atMostOnce);// 订阅的主题2
    //监听服务器发来的信息
    client.updates?.listen((List<MqttReceivedMessage<MqttMessage>> c) {
      final MqttPublishMessage recMess = c[0].payload as MqttPublishMessage;
      // 返回的数据
      final String pt = MqttPublishPayload.bytesToStringAsString(recMess.payload.message);
      print('订阅的主题:${c[0].topic}');
      print('服务器返回的数据信息:$pt');
      setState(() {
        _resStr = pt;
      });
    });
  }
  @override
  void initState() {
    super.initState();
    initClient();

  }
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title:const  Text("MQTT test",),backgroundColor: Colors.green,),
      body: Center(child: Text(_resStr,style: const TextStyle(fontSize: 40)),),
    );
  }
}

显示:

模仿第二点,向mosquitto发送代理后,手机显示:

本文参考资料:(感谢这位大佬!)Flutter框架高阶------使用MQTT协议进行信息传输_flutter mqtt-CSDN博客

相关推荐
TT_Close7 小时前
【Flutter×鸿蒙】FVM 不认鸿蒙 SDK?4步手动塞进去
flutter·swift·harmonyos
TT_Close9 小时前
【Flutter×鸿蒙】一个"插队"技巧,解决90%的 command not found
flutter·harmonyos
恋猫de小郭12 小时前
Flutter 发布官方 Skills ,Flutter 在 AI 领域再添一助力
android·前端·flutter
恋猫de小郭1 天前
2026 Flutter VS React Native ,同时在 AI 时代 VS Native 开发,你没见过的版本
android·前端·flutter
明君879971 天前
Flutter 如何给图片添加多行文字水印
前端·flutter
四眼肥鱼2 天前
flutter 利用flutter_libserialport 实现SQ800 串口通信
前端·flutter
火柴就是我2 天前
让我们实现一个更好看的内部阴影按钮
android·flutter
王晓枫2 天前
flutter接入三方库运行报错:Error running pod install
前端·flutter
shankss3 天前
Flutter 下拉刷新库 pull_to_refresh_plus 设计与实现分析
flutter
忆江南3 天前
iOS 深度解析
flutter·ios