Flutter通过 Coap发送组播

Flutter发送组播的流程

1.初始化 CoAP 客户端

需要初始化 CoAP 客户端并将其连接到组播地址和端口。您可以使用 CoAP 库提供的类来创建和配置客户端

复制代码
final client = CoapClient(
    Uri.parse('coap://224.0.1.1:5683'), // 组播地址和端口
);

2.创建 CoAP 请求

创建一个 CoAP 请求,设置请求类型(例如 GET、POST、PUT 等)、请求路径以及任何负载或选项

复制代码
CoapRequest request = CoapRequest.newGet();

 // request.addUriPath('/auth/test/$ACCESS_TOKEN/rpc'); // 设置资源路径

request.payloadString = 'Hello, CoAP Multicast!'; // 设置负载

3.发送请求

一旦请求准备就绪,您就可以使用 CoAP 客户端发送请求。发送请求后,等待服务端的响应

复制代码
var responses = client.sendMulticast(request);

4.处理响应

如果收到了响应,您可以从响应中提取数据并对其进行处理,例如显示在用户界面上或执行其他操作。如果未收到响应,您可以处理超时或其他错误情况

复制代码
await for (final response in responses) {

     print(response.payloadString);        

}

5.关闭连接

完成通信后,关闭 CoAP 客户端的连接,释放资源并确保网络资源的正常释放

复制代码
client.close();

6.全部代码

复制代码
TextButton(

     onPressed: () async {

       final client = CoapClient(

         Uri.parse('coap://224.0.1.1:5683'), // 组播地址和端口

       );

       try {

         CoapRequest request = CoapRequest.newGet();

         // 设置请求路径和负载

         // request.addUriPath('/auth/test/$ACCESS_TOKEN/rpc'); // 设置资源路径

         request.payloadString = 'Hello, CoAP Multicast!'; // 设置负载

         var responses = client.sendMulticast(request);

         await for (final response in responses) {

           print(response.payloadString);

         }

       } on Exception catch (e) {

         print('CoAP encountered an exception: $e');

       }



       client.close();

     },

     child: Text("发送组播")

),

测试数据是否发生成功

1.使用SockerTool软件进行测试

解压\\nas.nonagon\01-办公及开发软件\07-硬件开发工具\03-串口 USB CAN 网络 蓝牙调试助手\sockettool.rar,然后打开SocketTool V4.exe

2.创建组播服务

选中UDP Group后点击创建按钮,填写上上面代码中的组播地址和端口

3.测试

手机上发送内容,查看这里能否接收到,能接收到则代表成功

相关推荐
不爱吃糖的程序媛16 小时前
Flutter 三方库鸿蒙(OHOS)适配分析流程
flutter·华为·harmonyos
mocoding16 小时前
我这样用鸿蒙化Flutter三方库file_selector实现单图片和多图片选择
flutter·华为·harmonyos
牛马11116 小时前
flutter Riverpod 中的 overrideWith
android·java·flutter
牛马11117 小时前
flutter riverpod AsyncNotifier 和 Notifier
flutter
不爱吃糖的程序媛17 小时前
如何判断Flutter三方库是否需要OHOS适配开发?附完整适配指导
flutter·华为·harmonyos
kirk_wang18 小时前
Flutter艺术探索-Flutter渲染管道:RenderObject与Layer深度解析
flutter·移动开发·flutter教程·移动开发教程
微祎_18 小时前
Flutter for OpenHarmony:构建一个 Flutter 点击狂热游戏,深入解析响应式交互、动态反馈与高性能状态管理
flutter·游戏·交互
晚霞的不甘18 小时前
Flutter for OpenHarmony实现高性能流体粒子模拟:从物理引擎到交互式可视化
前端·数据库·经验分享·flutter·microsoft·计算机视觉
晚霞的不甘18 小时前
Flutter for OpenHarmony 流体气泡模拟器:用物理引擎与粒子系统打造沉浸式交互体验
前端·flutter·ui·前端框架·交互
一起养小猫18 小时前
Flutter for OpenHarmony 实战:打造功能完整的记账助手应用
android·前端·flutter·游戏·harmonyos