文档

UDP

更新时间:
一键部署

本文介绍登云梯JS开发框架中UDP组件所提供的相关方法说明,支持的硬件平台列表以及参考示例代码。

硬件平台

产品型号

是否支持

硬件类型

HaaS600Kit

开发板

HaaS510

DTU

HaaS520

DTU

HaaS530

DTU

HaaS531

DTU

HaaS632-LT32V

模组

HaaS600-EC600S

模组

HaaS600-EC600N

模组

HaaS600-EC600U

模组

HaaS600-N715

模组

createSocket()

创建一个UDP Socket实例。

入参

无。

返回

一个UDP Socket实例。

UDP Socket实例

事件

描述

'close'

Socket关闭时,会触发'close'事件。

'send'

Socket数据发送成功后,会触发'send'事件。

'message'

接收到新的数据包时,会触发'message'事件。

'error'

发生错误时,会触发'error'事件。

'message'事件的回调函数参数有:

属性

类型

描述

message

ArrayBuffer

接受到的UDP数据。

rinfo

Object

发送端地址信息,详细信息,请参见rinfo属性说明。

rinfo属性说明:

属性

类型

描述

host

String

发送端IP地址。

port

Number

发送端的端口。

'error'事件的回调函数参数有:

属性

类型

描述

error

String

错误信息。

UDPSocket.localPort

本地绑定的端口。

入参

无。

返回

无。

UDPSocket.bind(Number port)

绑定一个系统随机分配的可用端口,或绑定一个指定的端口号。

入参

属性

类型

是否必填

描述

port

Number

指定要绑定的端口号,不传则返回系统随机分配的可用端口。

返回

端口号,Number类型。

UDPSocket.send(Object target)

向指定的IP地址和Port发送消息。

入参

Object类型,属性如下:

属性

类型

是否必填

描述

address

String

要发消息的IP地址。

port

Number

要发送消息的端口号。

message

String | Array

要发送的数据。

success

Function

发送成功时的回调函数。

fail

Function

发送失败时的回调函数。

返回

无。

UDPSocket.close()

关闭UDP Socket实例,如果需要完整销毁UDP Socket实例,还需要将创建的UDP Socket实例置为NULL。

入参

无。

返回

无。

UDPSocket.on(String event, Function callback)

监听事件。

入参

无。

返回

无。

示例代码

import * as udp from 'udp'

var udpSocket = udp.createSocket();

// bind port
udpSocket.bind(8061);

udpSocket.on('send', function() {
  console.log('udp data send');
});

udpSocket.on('message', function(data, rinfo) {
  console.log('receive data from ' + rinfo.host + ' port: ' + rinfo.port);
  console.log('udp socket just receive data is: ' + data);
  udpSocket.close();
});

udpSocket.on('close', function() {
  console.log('udp close');
});

udpSocket.on('error', function(err) {
  console.log('udp error ' + err);
});

udpSocket.send({
  address: '192.168.193.2',
  port: 8848,
  message: 'hello, this is amp'
});