关于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博客

相关推荐
Cao_Shixin攻城狮19 小时前
[Flutter]Json序列化json_serializable使用属性全介绍
flutter·json·serializable
五味香1 天前
Java学习,反射
android·java·开发语言·python·学习·flutter·kotlin
收银系统源码那点事1 天前
零售餐饮收银台源码
flutter·uni-app·零售·收银系统源码·收银系统·连锁店收银系统
唯鹿2 天前
Flutter如何适配RTL
android·flutter
Mis_wenwen2 天前
flutter 解决webview加载重定向h5页面 返回重复加载问题
flutter·h5·webview·重定向
兰琛2 天前
Flutter 1.1:下载Flutter环境
android·flutter
sunly_2 天前
Flutter:购物车总结(单选,全选,定义数量,是否选中为obs响应式)
flutter
吴胜ws2 天前
Flutter中的Future和Stream
flutter
sunly_2 天前
Flutter:常见的页面布局:上边内容可滚动,底部固定一个按钮
android·javascript·flutter