批量查询设备信息
典型场景
已在物联网平台注册的设备,应用服务器若需要根据条件查看多个设备的详细信息(如厂商、型号、版本、状态和服务属性等信息),可调用此接口在物联网平台查询获取。
接口功能
支持应用服务器在物联网平台根据条件查询多个设备的详细信息,包括配置信息、状态信息、服务属性信息等。
接口原型
请求方法 |
GET |
---|---|
请求地址 |
https://server:port/iocm/app/dm/v1.4.0/devices?appId={appId}&deviceType={deviceType}&endTime={endTime}&gatewayId={gatewayId}&location={location}&name={name}&nodeType={nodeType}&pageNo={pageNo}&pageSize={pageSize}&select={select}&sort={sort}&startTime={startTime}&status={status} |
传输协议 |
HTTPS |
请求参数
参数 |
必选/可选 |
类型 |
位置 |
描述 |
---|---|---|---|---|
app_key |
必选 |
String |
header |
访问物联网平台的应用ID,在物联网平台创建应用时由平台分配获得。 |
Authorization |
必选 |
String |
header |
访问物联网平台的认证信息,值为“Bearer {accessToken}”,其中{accessToken}为调用鉴权接口返回的accessToken。 |
appId |
可选 |
String |
query |
访问物联网平台的应用ID,在物联网平台创建应用时由平台分配获得。此处填写授权应用的appId。 |
gatewayId |
可选 |
String |
query |
网关ID,用于标识一个网关设备。当设备是直连设备时,gatewayId与设备的deviceId一致。当设备是非直连设备时,gatewayId为设备所关联的直连设备(即网关)的deviceId。 “gatewayId”与“pageNo”不能同时为空。 |
nodeType |
可选 |
String |
query |
节点类型,取值:ENDPOINT/GATEWAY/UNKNOW。 |
deviceType |
可选 |
String |
query |
设备类型。 |
location |
可选 |
String |
query |
设备位置信息。 |
name |
可选 |
String |
query |
设备名称。 |
pageNo |
可选 |
Integer |
query |
分页查询时指定要查询的页码信息,默认值为0,取值范围为大于等于0的整数,值为0时,查询第一页。 “gatewayId”与“pageNo”不能同时为空。 |
pageSize |
可选 |
Integer |
query |
分页查询时每页显示的记录数,查询结果根据pageSize进行分页,默认值为25,取值范围为1-250的整数。 |
status |
可选 |
String |
query |
设备的状态,表示设备是否在线,取值范围:ONLINE、OFFLINE、INACTIVE、ABNORMAL。
|
startTime |
可选 |
String |
query |
查询注册设备信息时间在startTime之后的记录。时间格式:yyyyMMdd'T'HHmmss'Z',如 20151212T121212Z。 |
endTime |
可选 |
String |
query |
查询注册设备信息时间在endTime之前的记录。时间格式:yyyyMMdd'T'HHmmss'Z',如 20151212T121212Z。 |
sort |
可选 |
String |
query |
指定返回记录的排序。
缺省值:DESC。 |
select |
可选 |
String |
query |
指定返回记录,可取值:imsi。 |
响应参数
Status Code: 200 OK
参数 |
类型 |
描述 |
---|---|---|
totalCount |
Long |
查询的记录数量。 |
pageNo |
Long |
查询的页码。 |
pageSize |
Long |
查询每页信息的数量。 |
devices |
List<QueryDeviceDTO4Cloud2NA> |
设备分页列表信息。 |
参数 |
类型 |
描述 |
---|---|---|
deviceId |
String(256) |
设备ID,用于唯一标识一个设备,在注册设备时由物联网平台分配获得。 |
gatewayId |
String(256) |
网关ID,用于标识一个网关设备。当设备是直连设备时,gatewayId与设备的deviceId一致。当设备是非直连设备时,gatewayId为设备所关联的直连设备(即网关)的deviceId。 |
nodeType |
Enum |
节点类型,取值:ENDPOINT/GATEWAY/UNKNOW。 |
createTime |
String(256) |
创建设备的时间,时间格式:yyyyMMdd'T'HHmmss'Z',如20151212T121212Z。 |
lastModifiedTime |
String(256) |
最后修改设备的时间。 |
deviceInfo |
设备信息。 |
|
services |
List<DeviceService> |
设备服务列表。 |
alarmInfo |
设备告警信息。 |
参数 |
类型 |
描述 |
---|---|---|
nodeId |
String(256) |
设备唯一标识码。 |
name |
String(256) |
设备名称。 |
description |
String(2048) |
设备的描述信息。 |
manufacturerId |
String(256) |
厂商ID,唯一标识一个厂商。 |
manufacturerName |
String(256) |
厂商名称。 |
mac |
String(256) |
设备的MAC地址。 |
location |
String(2048) |
设备的位置信息。 |
deviceType |
String(256) |
设备类型,大驼峰命名方式,如MultiSensor、ContactSensor、CameraGateway。 |
model |
String(256) |
设备的型号。 |
swVersion |
String(256) |
设备的软件版本。 |
fwVersion |
String(256) |
设备的固件版本。 |
hwVersion |
String(256) |
设备的硬件版本。 |
imsi |
String |
NB-IoT终端的IMSI。 |
protocolType |
String(256) |
设备使用的协议类型。 |
radiusIp |
String |
Radius地址。 |
bridgeId |
String(256) |
Bridge标识,表示设备通过哪个Bridge接入物联网平台。 |
status |
String |
设备的状态,表示设备是否在线,取值范围:ONLINE、OFFLINE、INACTIVE、ABNORMAL。
|
statusDetail |
String(256) |
设备的状态详情,跟status取值对应。
|
mute |
String |
表示设备是否处于冻结状态,即设备上报数据时,平台是否会管理和保存。
|
supportedSecurity |
String |
表示设备是否支持安全模式。
|
isSecurity |
String |
表示设备当前是否启用安全模式。
|
signalStrength |
String(256) |
设备的信号强度。 |
sigVersion |
String(256) |
设备的sig版本。 |
serialNumber |
String(256) |
设备的序列号。 |
batteryLevel |
String(256) |
设备的电池电量。 |
设备向物联网平台上报设备状态时需要status、statusDetail成对上报。statusDetail建议仅用作显示,不建议用于逻辑判断。
参数 |
类型 |
描述 |
---|---|---|
serviceId |
String(256) |
设备的服务标识。 |
serviceType |
String(256) |
设备的服务类型。 |
serviceInfo |
设备的服务信息。 |
|
data |
ObjectNode(2097152) |
属性值对(Attribute-value pair)。 |
eventTime |
String(256) |
时间格式:yyyyMMdd'T'HHmmss'Z',如20151212T121212Z。 |
参数 |
类型 |
描述 |
---|---|---|
muteCmds |
List<String> |
屏蔽的设备控制命令列表 |
参数 |
类型 |
描述 |
---|---|---|
alarmSeverity |
String |
告警级别。 |
alarmStatus |
Boolean |
告警状态。 |
alarmTime |
String |
告警上报时间。 |
请求示例
Method: GET request: https://server:port/iocm/app/dm/v1.4.0/devices?gatewayId={gatewayId}&select=imsi Header: app_key: ****** Authorization: Bearer ***** Content-Type: application/json
响应示例
response: Status Code: 200 OK Content-Type: application/json Body: { "totalCount":"****", "pageNo":"*****", "pageSize":"*****", "devices":[ { "deviceId":"xxxxx", "gatewayId":"xxxxx", "nodeType":"xxxxx", "deviceInfo":{ "nodeId": "123456", "name":"Sensor_12", "manufacturerName":"wulian", "deviceType":"gateway", "model":"90", "mac":"C7EA1904004B1204", "swVersion":"th", "fwVersion":"seu", "hwVersion":"sru", "protocolType":"zigbee", "description":"smockdetector", "imsi":"xxxxx" }, "services":[ { "serviceType":"air_conditioner", "serviceId":"1", "data":{ "battery_low":"1" } }, { "serviceType":"air_conditioner", "serviceId":"jkh", "data":{ "battery_low":"jhj" } } ] }, { "deviceId":"xxxxx", "gatewayId":"xxxxx", "nodeType":"xxxxx", "deviceInfo":{ "nodeId": "223456", "name":"Sensor_12", "manufacturerName":"wulian", "type":"90", "model":" 90", "mac":"C7EA1904004B1204", "swVersion":"…", "fwVersion":"…", "hwVersion":"…", "protocolType":"zigbee", "description":"smockdetector", "imsi":"xxxxx" }, "services":[ { "serviceType":"air_conditioner", "serviceId":"1", "data":{ "battery_low":"1" } }, { "serviceType":"air_conditioner", "serviceId":"1", "data":{ "battery_low":"1" } } ] } ] }
错误码
Http状态码 |
错误码 |
错误描述 |
说明 |
---|---|---|---|
400 |
100216 |
The application input is invalid. |
应用输入无效。 处理建议:请参考请求参数说明检查接口请求中的参数是否有误。 |
400 |
100218 |
The gatewayId and pageNo can't be both null. |
网关ID和pageNo不能同时为空。 处理建议:请检查请求参数中gatewayId或pageNo是否填写。 |
400 |
100405 |
The request parameter is invalid. |
请求参数不合法。 处理建议:请参考请求参数说明检查接口请求中的参数是否有误。 |
403 |
100203 |
The application is not existed. |
应用不存在。 处理建议:
|
403 |
100217 |
The application hasn't been authorized. |
应用未被授权。 处理建议:若非应用授权场景,请确认请求参数中的appId为空。 |
403 |
1010009 |
app throttle exceed. |
应用调用接口过于频繁,超过流控值(默认值是100次/60s)。 处理建议:联系物联网平台维护人员调大流控阈值或者控制接口的调用频率。 |
403 |
1010005 |
App_key or access_token is invalid. |
错误的token信息。 处理建议:请检查接口请求中所携带的accessToken是否有误。 |
500 |
100203 |
The application is not existed. |
应用不存在。 处理建议:
|
500 |
50252 |
Internal server error. |
服务器运行内部错误。 处理建议:物联网平台内部错误,请联系物联网平台维护人员处理。 |