鸿蒙UDP

具体文档地址

ts 复制代码
import socket from '@ohos.net.socket';

let udp = socket.constructUDPSocketInstance();
udp.bind({address: '192.168.xx.xxx', port: 8080, family: 1}).then(() => {
  console.log('bind success');

  udp.getState().then(data => {
    console.log('getState success:' + JSON.stringify(data));
  }).catch(err => {
    console.log('getState fail');
  });

  // https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V2/js-apis-socket-0000001477981433-V2#ZH-CN_TOPIC_0000001523808874__setextraoptions
  // udp.setExtraOptions({
  //   receiveBufferSize:1000,
  //   sendBufferSize:1000,
  //   reuseAddress:false,
  //   socketTimeout:6000,
  //   broadcast:true
  // }, err=> {
  //   if (err) {
  //     console.log('setExtraOptions fail');
  //     return;
  //   }
  //   console.log('setExtraOptions success');
  // })

}).catch(err => {
  console.log('bind fail');
});

udp.send({
  data:'Hello, server!',
  address: {
    address:'192.168.xx.xxx',
    port:1234,
    family:1
  }
}).then(() => {
  console.log('send success');
}).catch(err => {
  console.log('send fail');
});

// 订阅UDPSocket连接的接收消息事件
udp.on('message', value => {
  console.log("on message, message:" + value.message + ", remoteInfo:" + value.remoteInfo);
});


// let callback = value =>{
//   console.log("on message, message:" + value.message + ", remoteInfo:" + value.remoteInfo);
// }
// udp.on('message', callback);
// // 可以指定传入on中的callback取消一个订阅,也可以不指定callback清空所有订阅。
// udp.off('message', callback);
// udp.off('message');


// https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V2/js-apis-socket-0000001477981433-V2#ZH-CN_TOPIC_0000001523808874__onlistening--close
udp.on('listening', () => {
  console.log("on listening success");
});
udp.on('close', () => {
  console.log("on close success" );
});

// 可以指定传入on中的callback取消一个订阅,也可以不指定callback清空所有订阅。
// udp.off('listening', callback1);
// udp.off('listening');


// udp.on('error', err => {
//   console.log("on error, err:" + JSON.stringify(err))
// });
//
// // 可以指定传入on中的callback取消一个订阅,也可以不指定callback清空所有订阅。
// udp.off('error', callback);
// udp.off('error');




// let promise = udp.close();
// promise.then(() => {
//   console.log('close success');
// }).catch(err => {
//   console.log('close fail');
// });

确实利好前端

相关推荐
木斯佳15 分钟前
HarmonyOS 6实战(源码教学篇)— Speech Kit TextReader:【仿某云音乐接入语音朗读控件】
华为·harmonyos
南村群童欺我老无力.1 小时前
Flutter 框架跨平台鸿蒙开发 - 校园生活一站式:打造智慧校园服务平台
flutter·华为·harmonyos
南村群童欺我老无力.2 小时前
Flutter 框架跨平台鸿蒙开发 - 城市文创打卡:探索城市文化创意之旅
android·flutter·华为·harmonyos
yingdonglan4 小时前
Flutter 框架跨平台鸿蒙开发 ——AnimatedBuilder性能优化详解
flutter·性能优化·harmonyos
程序员清洒4 小时前
Flutter for OpenHarmony:Icon 与 IconButton — 图标系统集成
前端·学习·flutter·华为
时光慢煮4 小时前
打造跨端驾照学习助手:Flutter × OpenHarmony 实战解析
学习·flutter·华为·开源·openharmony
菜鸟小芯4 小时前
【开源鸿蒙跨平台开发先锋训练营】DAY8~DAY13 底部选项卡&首页功能实现
flutter·harmonyos
大雷神4 小时前
HarmonyOS智慧农业管理应用开发教程--高高种地-- 第19篇:语音合成 - TTS语音播报
华为·语音识别·harmonyos
b2077214 小时前
Flutter for OpenHarmony 身体健康状况记录App实战 - 提醒设置实现
python·flutter·macos·cocoa·harmonyos
xingfanjiuge5 小时前
Flutter框架跨平台鸿蒙开发——ListView.builder深度解析
flutter·华为·harmonyos