日本熟妇hd丰满老熟妇,中文字幕一区二区三区在线不卡 ,亚洲成片在线观看,免费女同在线一区二区

Python SDK使用說明

物聯網平臺提供Python語言的云端SDK供開發人員使用。本文介紹云端Python SDK的安裝和配置,及使用Python SDK調用云端API的示例。

安裝SDK

  1. 安裝Python開發環境。

    訪問Python官網下載Python安裝包,并完成安裝。目前Python SDK支持Python的3.6及以上版本。

  2. 安裝Python的包管理工具pip。(如果您已安裝pip,請忽略此步驟。)

    訪問pip 官網下載pip安裝包,并完成安裝。

  3. 安裝IoT Python SDK。

    以管理員權限執以下命令,安裝IoT Python SDK。SDK使用說明,請參見新版alibabacloud-python-sdk

    pip3 install alibabacloud_tea_openapi
    
    # 安裝新版本IoT SDK。
    pip3 install alibabacloud_iot20180120
    # 安裝指定SDK版本,以3.0.9版本為例。
    pip3 install alibabacloud_iot20180120==3.0.9 
    
  4. 安裝alibabacloud-tea-console包,用于控制臺打印日志。

    以管理員權限執行以下命令:

    pip3 install alibabacloud-tea-console
  5. 將IoT Python SDK相關文件引入Python文件。

    from Tea.core import TeaCore
    from alibabacloud_iot20180120.client import Client as IotClient
    from alibabacloud_tea_openapi import models as open_api_models
    from alibabacloud_iot20180120 import models as iot_models
    from alibabacloud_tea_console.client import Client as ConsoleClient
    from alibabacloud_tea_util.client import Client as UtilClient
    ...

初始化SDK

  1. 創建對象config,存放SDK初始化信息(AccessKey IDAccessKey Secret、地域ID等)。

  2. 創建對象實例client,通過IotClient(config)方法,加載config中的SDK信息,完成SDK客戶端初始化。

以華東2(上海)地域及其服務接入地址為例,初始代碼如下。實際場景設置中,需使用您的物聯網平臺服務所在地域。

config = open_api_models.Config()
# 您的AccessKey ID
config.access_key_id = os.environ.get('ALICLOUD_ACCESS_KEY_ID')
# 您的AccessKey Secret
config.access_key_secret = os.environ.get('ALICLOUD_ACCESS_KEY_SECRET')
# 您的可用區ID
config.region_id = 'cn-shanghai'
client = IotClient(config)

參數

說明

region_id

您的物聯網平臺服務的地域ID,用于拼接服務接入地址,格式為:iot.${RegionId}.aliyuncs.com。

您可在物聯網平臺控制臺左上方,查看當前服務所在地域。

地域ID的表達方法,請參見地域和可用區

SDK客戶端的HTTP請求配置、代理配置、超時機制、重試機制等配置方式,請參見進階配置

發起調用

物聯網平臺云端SDK為每個API封裝了一個類,命名為${API名稱}+"Request",用于API的調用請求。

調用步驟

  1. 已完成SDK客戶端初始化。具體內容,請參見初始化SDK

  2. 創建對應API的調用請求,生成${API名稱}+"Request"類對象實例request

  3. 通過對象實例request,使用"set_"+${請求參數的名稱}方法,設置API所需的請求參數值。

  4. 通過初始化SDK的對象實例client,使用${經過下劃線分隔單詞的API名稱}(request)方法,承載API調用結果。其中,后綴為_async的方法表示異步方法

    例如:invoke_things_service(request)invoke_things_service_async(request)

物聯網平臺云端API,請參見API列表。有關request中請求參數說明,及response中返回參數說明,請參見對應API文檔。

本文以調用Pub接口發布消息到Topic為例。請求參數信息,請參見Pub

重要

以下代碼中iotInstanceId為實例ID。實例的詳細說明,請參見實例概述

購買實例方法,請參見購買企業版實例

獲取實例ID方法,請參見物聯網平臺實例相關問題

request = iot_models.PubRequest(
    # 物聯網平臺實例ID。
    iot_instance_id='${iotInstanceId}',
    # 產品ProductKey。
    product_key='${productKey}',
    # 要發送的消息主體,hello world Base64 String。
    message_content='aGVsbG8gd29ybGQ=',
    # 要接收消息的設備的自定義Topic。
    topic_full_name='/${productKey}/${deviceName}/user/get',
    # 指定消息的發送方式,支持QoS0和QoS1。
    qos=0
)
response = client.pub(request)
print('response : ' + response)

完整示例代碼

說明

實際場景中,請參照上文的參數說明,替換對應參數值。

# -*- coding: utf-8 -*-
import sys
from typing import List
from Tea.core import TeaCore
from alibabacloud_iot20180120.client import Client as IotClient
from alibabacloud_tea_openapi import models as open_api_models
from alibabacloud_iot20180120 import models as iot_models
from alibabacloud_tea_console.client import Client as ConsoleClient
from alibabacloud_tea_util.client import Client as UtilClient

access_key_id = os.environ.get('ACCESS_KEY_ID')
access_key_secret = os.environ.get('ACCESS_KEY_SECRET')

class Sample:
    def __init__(self):
        pass

    @staticmethod
    def create_client(
        access_key_id: str,
        access_key_secret: str,
    ) -> IotClient:
        """
        使用AK&SK初始化Client
        """
        使用AK&SK初始化賬號Client
        @param access_key_id:
        @param access_key_secret:
        @return: Client
        @throws Exception
        """
        config = open_api_models.Config()
        # 您的AccessKey ID
        config.access_key_id = os.environ.get('ALICLOUD_ACCESS_KEY_ID')
        # 您的AccessKey Secret
        config.access_key_secret = os.environ.get('ALICLOUD_ACCESS_KEY_SECRET')
        # 您的可用區ID
        config.region_id = 'cn-shanghai'
        return Iot20180120Client(config)

    @staticmethod
    def main(
        args: List[str],
    ) -> None:
        """
        同步調用方式
        """
        try:
            client = Sample.create_client('${accessKey}', '${accessKeySecret}')
            request = iot_models.PubRequest(
                # 物聯網平臺實例ID。
                iot_instance_id='${iotInstanceId}',
                # 產品ProductKey。
                product_key='${productKey}',
                # 要發送的消息主體,hello world Base64 String。
                message_content='eyJ0ZXN0IjoidGFzayBwdWIgYnJvYWRjYXN0In0=',
                # 要接收消息的設備的自定義Topic。
                topic_full_name='/${productKey}/${deviceName}/user/get',
                # 指定消息的發送方式,支持QoS0和QoS1。
                qos=0
            )
            response = client.pub(request)
            ConsoleClient.log(UtilClient.to_jsonstring(TeaCore.to_map(response)))
        except Exception as error:
            ConsoleClient.log(error.message)

    @staticmethod
    async def main_async(
        args: List[str],
    ) -> None:
        """
        異步調用方式
        """
        try:
            client = Sample.create_client('${accessKey}', '${accessKeySecret}')
            request = iot_models.PubRequest(
                # 物聯網平臺實例ID。
                iot_instance_id='${iotInstanceId}',
                # 產品ProductKey。
                product_key='${productKey}',
                # 要發送的消息主體,hello world Base64 String。
                message_content='eyJ0ZXN0IjoidGFzayBwdWIgYnJvYWRjYXN0In0=',
                # 要接收消息的設備的自定義Topic。
                topic_full_name='/${productKey}/${deviceName}/user/get',
                # 指定消息的發送方式,支持QoS0和QoS1。
                qos=0
            )
            response = await client.pub_async(request)
            ConsoleClient.log(UtilClient.to_jsonstring(TeaCore.to_map(response)))
        except Exception as error:
            ConsoleClient.log(error.message)


if __name__ == '__main__':
    Sample.main(sys.argv[1:])

附錄:示例代碼

前往物聯網平臺云端SDK示例中心查看或下載API調用的示例代碼。示例代碼中包含Java、Python、PHP、Node.js、Go、C++和.NET等版本SDK示例。

阿里云OpenAPI開發者門戶提供API在線調試工具。在API調試頁面,您可以快速檢索和體驗調用API。系統會根據您輸入的參數同步生成各語言SDK的代碼示例。各語言SDK代碼示例顯示在頁面右側SDK示例頁簽下供您參考。在調用結果頁簽下,可查看API調用的真實請求URL和JSON格式的返回結果。