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

Java SDK使用說明

物聯網平臺提供的Java SDK,可幫助開發人員通過Java程序更便捷地操作物聯網平臺。開發人員可以添加包含Maven依賴的SDK,也可以下載安裝包到本地直接安裝。

安裝SDK

  1. 安裝Java開發環境。

    您可以從Java 官方網站下載,并按說明安裝Java開發環境。推薦安裝Java 8及以上版本。

  2. 安裝IoT Java SDK。

    1. 訪問Apache Maven 官網下載Maven軟件。

    2. 添加Maven項目依賴。

      重要

      以下version為示例值,最新版本信息,請參見OpenAPI門戶物聯網平臺的SDK安裝方式

      • IoT Java SDK的Maven依賴坐標:

        <!-- https://mvnrepository.com/artifact/com.aliyun/iot20180120 -->
        <dependency>
            <groupId>com.aliyun</groupId>
            <artifactId>iot20180120</artifactId>
            <version>4.2.0</version>
        </dependency>
      • 阿里云Java SDK公共包Maven依賴坐標:

        <dependency>
          <groupId>com.aliyun</groupId>
          <artifactId>tea-openapi</artifactId>
          <version>0.2.2</version>
        </dependency>

Java SDK源碼的更多信息,請參見alibabacloud-java-sdk

初始化SDK

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

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

    后續調用API的RequestResponse參數從com.aliyun.iot20180120.models中獲取。

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

Config config = new Config()
    // 您的AccessKey ID
    .setAccessKeyId(accessKeyId)
    // 您的AccessKey Secret
    .setAccessKeySecret(accessKeySecret);
// 訪問的域名
config.endpoint = "iot.cn-beijing.aliyuncs.com";

Client client = new Client(config);

參數

說明

accessKeyId

您阿里云賬號的AccessKey ID

您可在阿里云官網控制臺AccessKey管理中創建或查看您的AccessKey。

accessKeySecret

您阿里云賬號的AccessKey Secret

regionId

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

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

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

重要

為避免將AccessKey硬編碼到業務代碼中帶來的安全風險,可采用配置環境變量的方法管理AccessKey。

您需在本地操作系統中添加環境變量ALIBABA_CLOUD_ACCESS_KEY_ID和ALIBABA_CLOUD_ACCESS_KEY_SECRET,并分別寫入已準備好的AccessKey ID和AccessKey Secret。

在示例代碼中可通過以下方法獲取:

  • System.getenv("ALIBABA_CLOUD_ACCESS_KEY_ID")

  • System.getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET")

SDK客戶端的HTTP請求配置、代理配置、超時機制、重試機制等配置方式,請參見阿里云升級版Java SDK使用指南

發起調用

物聯網平臺云端SDK為每個API封裝兩個類,分別命名為${API名稱}+"Request"${API名稱}+"Response",分別用于承載API的調用請求和調用結果。

調用步驟

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

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

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

  4. 創建${API名稱}+"Response"類的對象實例response承載響應結果:使用Client對象實例client${API名稱}(request)方法,獲取API對應request的響應結果,包含服務端響應的bodyheaders

  5. 通過對象實例responsebody成員對象,使用get+${返回參數的名稱}方法,可獲取對應返回參數的值。

    例如:response.getbody.getSuccess()用于獲取是否調用成功的標識,其中Success為API的通用返回參數。通用返回參數還包含RequestIdErrorMessageCode

  6. 使用catch()方法處理異常報錯。

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

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

重要

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

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

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

PubRequest request = new PubRequest()
    .setIotInstanceId("${iotInstanceId}")
    .setProductKey("${productKey}")
    .setMessageContent(Base64.getEncoder().encodeToString("hello world".getBytes()))
    .setTopicFullName("/${productKey}/${deviceName}/user/get")
    .setQos(0);//目前支持QoS0和QoS1。 
try {
    PubResponse response = client.pub(request);
    // response中包含服務端響應的body和headers。 
    //獲取本次調用requestId。
    System.out.println(response.getBody().getRequestId());
    //調用是否成功。
    System.out.println(response.getBody().getSuccess());
    
    //調用成功。
    if (response.getBody().getSuccess()) {
        //獲取云端消息ID。
        System.out.println(response.getBody().getMessageId());
        
        //do業務邏輯。
        
    } else {
    //調用失敗。            
        //獲取調用失敗錯誤碼。
        System.out.println(response.getBody().getCode());
        //獲取調用失敗錯誤描述。
        System.out.println(response.getBody().getErrorMessage());
     }
} catch (TeaException error) {
    //服務端業務異常。
    System.out.println(error.getCode());
    System.out.println(error.getMessage());
} catch (Exception e) {
    //其他運行時異常。
    e.printStackTrace();
}

完整示例代碼

說明

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

import com.aliyun.iot20180120.Client;
import com.aliyun.iot20180120.models.PubRequest;
import com.aliyun.iot20180120.models.PubResponse;
import com.aliyun.tea.TeaException;
import com.aliyun.teaopenapi.models.Config;
import java.util.Base64;

public class IotSdkDemo {
    /**
     * 使用AK&SK初始化Client。
     */
    private static Client createClient(String accessKeyId, String accessKeySecret) throws Exception {
        com.aliyun.teaopenapi.models.Config config = new com.aliyun.teaopenapi.models.Config()
                // 必填,您的 AccessKey ID
                .setAccessKeyId(accessKeyId)
                // 必填,您的 AccessKey Secret
                .setAccessKeySecret(accessKeySecret);
        // Endpoint 請參考 https://api.aliyun.com/product/Iot
        config.endpoint = "iot.cn-beijing.aliyuncs.com";
        return new Client(config);
    }

    public static void main(String[] args) {
        try {
            Client client = createClient(accessKey, accessKeySecret);
            PubRequest request = new PubRequest()
                .setIotInstanceId("${iotInstanceId}")
                .setProductKey("${productKey}")
                .setMessageContent(Base64.getEncoder().encodeToString("hello world".getBytes()))
                .setTopicFullName("/${productKey}/${deviceName}/user/get")
                .setQos(0);//目前支持QoS0和QoS1。 
            
            PubResponse response = client.pub(request);            
            //獲取本次調用requestId。
      System.out.println(response.getBody().getRequestId());
      //調用是否成功。
      System.out.println(response.getBody().getSuccess());
            
         //調用成功。
       if (response.getBody().getSuccess()) {
          //獲取云端消息ID。
          System.out.println(response.getBody().getMessageId());
        
          //do業務邏輯。
      } else {
       //調用失敗。            
          //獲取調用失敗錯誤碼。
             System.out.println(response.getBody().getCode());
          //獲取調用失敗錯誤描述。
          System.out.println(response.getBody().getErrorMessage());
      }
        } catch (TeaException error) {
            //服務端業務異常。
      System.out.println(error.getCode());
      System.out.println(error.getMessage());
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

附錄:示例代碼

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

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