すべてのプロダクト
Search
ドキュメントセンター

Alibaba Cloud SDK:例外処理

最終更新日:Jan 15, 2025

このトピックでは、Alibaba Cloud Darabonba SDK for Go の例外の種類と、これらの例外の処理方法について説明します。

Alibaba Cloud Darabonba SDK for Go を使用するときに発生する可能性のある例外は、次の種類に分類されます。

  • error: このタイプの例外は、ビジネスエラー以外のエラーによって発生します。たとえば、SDK ソースファイルが変更されたために検証に失敗した場合、または解析に失敗した場合、このタイプの例外がスローされます。

  • SDKError: このタイプの例外は、ビジネスエラーによって発生します。このタイプの例外を処理するために、次の 3 つのパラメーターが提供されます。

    • Code: 例外が発生したときに返されるエラーコード。

    • Message: 例外が発生したときに返されるエラーメッセージ。メッセージには、例外がスローされた API リクエストの ID が含まれています。

    • Data: 例外に対してサーバーから返される詳細なエラー情報。

重要

使用している SDK が最新バージョンであることを確認してください。

github.com/alibabacloud-go/darabonba-openapi/v2

github.com/alibabacloud-go/tea-utils/v2

github.com/alibabacloud-go/tea

github.com/alibabacloud-go/vpc-20160428/v6

package main

import (
    "fmt"
    openapi "github.com/alibabacloud-go/darabonba-openapi/v2/client"
    ecs20160428 "github.com/alibabacloud-go/ecs-20140526/v4/client"
    util "github.com/alibabacloud-go/tea-utils/v2/service"
    "github.com/alibabacloud-go/tea/tea"
    "os"
)

/**
 * AccessKey ID と AccessKey シークレットを使用してクライアントを初期化します。
 * @param accessKeyId
 * @param accessKeySecret
 * @return Client
 * @throws Exception
 */
func createClient() (_result *ecs20160428.Client, _err error) {
    config := &openapi.Config{
       // 必須。次の環境変数がコードランタイム環境で設定されていることを確認します: ALIBABA_CLOUD_ACCESS_KEY_ID。
       AccessKeyId: tea.String(os.Getenv("ALIBABA_CLOUD_ACCESS_KEY_ID")),
       // 必須。次の環境変数がコードランタイム環境で設定されていることを確認します: ALIBABA_CLOUD_ACCESS_KEY_SECRET。
       AccessKeySecret: tea.String(os.Getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET")),
    }
    config.RegionId = tea.String("<regionId>")
    _result = &ecs20160428.Client{}
    _result, _err = ecs20160428.NewClient(config)
    return _result, _err
}

func main() {
    client, _err := createClient()
    if _err != nil {
       fmt.Printf("Error creating client: %v\n", _err)
       return
    }
    describeRegionsRequest := &ecs20160428.DescribeRegionsRequest{}
    resp, tryErr := func() (_result *ecs20160428.DescribeRegionsResponse, _e error) {
       defer func() {
          if r := tea.Recover(recover()); r != nil {
             _e = r
          }
       }()
       _result, _err = client.DescribeRegionsWithOptions(describeRegionsRequest, &util.RuntimeOptions{})
       if _err != nil {
          return nil, _err
       }
       return _result, nil
    }()

    if tryErr != nil {
       if sdkError, ok := tryErr.(*tea.SDKError); ok { // エラーの説明に基づいて、tryErr エラーのタイプが *tea.SDKError であるかどうかを判断します。
          fmt.Println(tea.StringValue(sdkError.Message))
          fmt.Println(tea.StringValue(sdkError.Code))
          fmt.Println(tea.StringValue(sdkError.Data))
       } else {
          fmt.Println(tea.String(tryErr.Error()))
       }
    } else {
       fmt.Println(resp.Body)
    }
}