このトピックでは、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)
}
}