物联网数据分析 PHP SDK使用说明

By | 2021年4月23日

物联网平台提供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。

  1. 安装PHP开发环境。
    需安装PHP 5.5.0或更高版本。访问
    PHP官网下载PHP安装包,并完成安装。
  2. 安装Composer。
    目前,通过Composer管理IoT PHP SDK,因此需在系统中安装Composer。

    • Windows系统用户,请访问getcomposer.org,下载、安装Composer-Setup.exe
    • 使用cURL命令安装Composer。
      curl -sS https://getcomposer.org/installer | php
    说明 如果由于网络问题无法安装,可以使用
    阿里云Composer全量镜像

  3. 添加以下依赖,安装IoT PHP SDK。
    composer require alibabacloud/iot

    PHP SDK详情和使用指导,请参见openapi-sdk-php-iotAlibaba Cloud SDK for PHP

初始化SDK

以调用华东2(上海)地域的API为例,初始化代码如下。

<?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的调用请求。物联网平台云端API,请参见API列表

本文以调用Pub接口发布消息到Topic为例。

有关如何设置request中请求参数,请参见对应API文档。以下示例,请参见Pub

注意 以下代码中iotInstanceId为实例ID,企业版实例填写
实例ID,公共实例要删除代码
$request->setIotInstanceId("iotInstanceId");

关于如何购买企业版实例,请参见实例管理

$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);

附录:Demo

下载物联网平台云端SDK Demo。Demo中包含Java、Python、PHP、.NET和Go版本SDK示例。

阿里云OpenAPI开发者门户提供API在线调试工具。在API调试页面,您可以快速检索和体验调用API。系统会根据您输入的参数同步生成各语言SDK的Demo代码。各语言SDK Demo显示在页面右侧SDK示例页签下供您参考。在调用结果页签下,查看API调用的真实请求URL和JSON格式的返回结果。

请关注公众号获取更多资料

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注