BatchGetDeviceState

调用该接口批量查看指定设备的运行状态,包括设备当前状态、设备状态变更时间和设备最后一次上线时间等。

使用说明

调用本接口时:

  • 请求参数同时传入ProductKey和多个DeviceName:查询同一产品多个设备的运行状态。
  • 请求参数传入多个IotId:可传入不同产品下设备的IotId,查询不同产品下设备的运行状态。
重要 单次调用本接口最多可查询50个设备的运行状态。

QPS限制

单个阿里云账号调用该接口的每秒请求数(QPS)最大限制为50。

说明 单个阿里云账号下的所有RAM用户共享该阿里云账号的配额。

调试

您可以在OpenAPI Explorer中直接运行该接口,免去您计算签名的困扰。运行成功后,OpenAPI Explorer可以自动生成SDK代码示例。

请求参数

名称

类型

是否必选

示例值

描述

Action String BatchGetDeviceState

系统规定参数。取值:BatchGetDeviceState。

DeviceName.N RepeatList light

要查看运行状态的设备的名称列表。

重要 如果传入该参数,需同时传入ProductKey
IotInstanceId String iot_instc_pu****_c*-v64********

实例ID。您可在物联网平台控制台的实例概览页面,查看当前实例的ID

重要
  • 若有ID值,必须传入该ID值,否则调用会失败。
  • 若ID值,则无需传入。

实例的更多信息,请参见实例概述

ProductKey String a1BwAGV****

要查看运行状态的设备所属的产品ProductKey

重要 如果传入该参数,需同时传入DeviceName
IotId.N RepeatList Q7uOhVRdZRRlDnTLv****00100

要查看运行状态的设备ID列表。

重要 IotId作为设备唯一标识符,和ProductKeyDeviceName组合是一一对应的关系。如果传入该参数,则无需传入ProductKeyDeviceName。如果您同时传入IotIdProductKeyDeviceName组合,则以IotId为准。

调用API时,除了本文介绍的该API的特有请求参数,还需传入公共请求参数。公共请求参数说明,请参见公共参数文档

返回数据

名称

类型

示例值

描述

Code String iot.system.SystemException

调用失败时,返回的错误码。更多信息,请参见错误码

DeviceStatusList Array of DeviceStatus

调用成功时,返回设备状态信息列表,请参见DeviceStatus下的参数。

DeviceStatus
AsAddress String 192.0.2.1

设备IP地址。

DeviceId String dwnS41bhNxjslDAI****

设备ID(旧版参数)。

说明 该参数是旧版本遗留参数,已无实际作用,不能用来标识设备。目前,有效的设备标识符为IotIdProductKeyDeviceName组合。
DeviceName String light

设备名称。

IotId String dwnS41bhNxjslDAI****000100

设备ID,物联网平台为设备颁发的唯一标识。

LastOnlineTime String 2020-01-17 16:19:11

设备最后一次上线的时间。

Status String OFFLINE

设备状态。取值:

  • ONLINE:设备在线。
  • OFFLINE:设备离线。
  • UNACTIVE:设备未激活。
  • DISABLE:设备已禁用。
Timestamp Long 1557062301656

设备状态变更时间。单位为毫秒。

ErrorMessage String 系统异常

调用失败时,返回的出错信息。

RequestId String E55E50B7-40EE-4B6B-8BBE-D3ED55CCF565

阿里云为该请求生成的唯一标识符。

Success Boolean true

是否调用成功。

  • true:调用成功。
  • false:调用失败。

示例

请求示例

https://iot.cn-shanghai.aliyuncs.com/?Action=BatchGetDeviceState
&productKey=a1BwAGV****
&DeviceName.1=device1
&DeviceName.2=device2
&<公共请求参数>

正常返回示例

XML格式

<BatchGetDeviceStateResponse>
  <DeviceStatusList>
        <DeviceStatus>
              <Status>OFFLINE</Status>
              <DeviceId>dwnS41bhNxjslDAI****</DeviceId>
              <DeviceName>Humidity</DeviceName>
              <AsAddress>192.0.2.1</AsAddress>
              <LastOnlineTime>2020-01-17 16:19:11</LastOnlineTime>
              <Timestamp>1557062301656</Timestamp>
              <IotId>dwnS41bhNxjslDAI****000100</IotId>
        </DeviceStatus>
  </DeviceStatusList>
  <RequestId>3258D872-EDC5-4039-B564-C27ED7176741</RequestId>
  <Success>true</Success>
</BatchGetDeviceStateResponse>

JSON格式

{
	"DeviceStatusList": {
		"DeviceStatus": [
			{
				"Status": "OFFLINE",
				"DeviceId": "dwnS41bhNxjslDAI****",
				"DeviceName": "Humidity",
				"AsAddress": "192.0.2.1",
				"LastOnlineTime": "2020-01-17 16:19:11",
                "Timestamp":1557062301656,
				"IotId": "dwnS41bhNxjslDAI****000100"
			}
		]
	},
	"RequestId": "3258D872-EDC5-4039-B564-C27ED7176741",
	"Success": true
}