物联网平台提供PHP语言的云端SDK供开发人员使用。本文介绍云端PHP SDK的安装和配置,及使用PHP SDK调用云端API的示例。
安装PHP SDK
IoT PHP SDK是Alibaba Cloud SDK for PHP的一部分。如果您已安装Alibaba Cloud SDK for PHP,则无需再安装IoT PHP SDK。
初始化SDK
以调用华东2(上海)地域的API为例,初始化代码如下。
首先创建对象$iClientProfile,存放SDK初始化信息,然后创建DefaultAcsClient对象实例$client,通过DefaultAcsClient($iClientProfile)
方法,加载SDK信息,完成SDK客户端初始化。
<?php
include_once 'aliyun-php-sdk-core/Config.php';
use \Iot\Request\V20180120 as Iot;
//设置您的AccessKeyId/AccessSecret/ProductKey
$accessKeyId = "";
$accessSecret = "";
$iClientProfile = DefaultProfile::getProfile("cn-shanghai", $accessKeyId, $accessSecret);
$client = new DefaultAcsClient($iClientProfile);
参数 | 说明 |
---|---|
$accessKeyId | 您账号的AccessKey ID。
您可在阿里云官网控制台AccessKey管理中创建或查看您的AccessKey。 |
$accessSecret | 您账号的AccessKey Secret。 |
$iClientProfile | 用于存放SDK初始化信息,其中cn-shanghai 是您的物联网平台服务的地域代码。
您可在物联网平台控制台左上方,查看当前服务所在地域。 地域代码的表达方法,请参见地域和可用区。 |
发起调用
物联网平台云端SDK为每个API封装了一个类,命名为${API名称}+"Request"
,用于API的调用请求。通过该类的对象实例$request
,使用"set"+${请求参数的名称}
方法,设置请求参数值。通过初始化SDK的对象实例$client,使用getAcsResponse($request)
方法,承载API调用结果。
物联网平台云端API,请参见API列表。有关request
中请求参数说明,及response
中返回参数说明,请参见对应API文档。
本文以调用Pub接口发布消息到Topic为例。请求参数信息,请参见Pub。
- 若有ID值,必须传入该ID值,否则调用API会失败。
- 若无实例概览页面或ID值,则无需传入。
实例的详细内容,请参见实例概述。
$request = new Iot\PubRequest();
$request->setIotInstanceId("iotInstanceId");
$request->setProductKey("productKey");
$request->setMessageContent("aGVsbG93b3JsZA="); //hello world Base64 String.
$request->setTopicFullName("/productKey/deviceName/user/get"); //消息发送到的Topic全名.
$response = $client->getAcsResponse($request);
print_r($response);
附录:示例代码
下载物联网平台云端SDK示例代码。示例代码中包含Java、Python、PHP、.NET和Go版本SDK示例。
阿里云提供API在线调试工具OpenAPI Explorer。在OpenAPI Explorer页面,您可以快速检索和试验调用API。系统可根据您输入的参数同步生成各语言SDK的示例代码。各语言SDK示例代码显示在页面右侧示例代码页签下。在调试结果页签下,查看API调用的真实请求URL和JSON格式的返回结果。