このトピックでは、Go SDK V2 を使用してオブジェクトのタグをクエリする方法について説明します。
使用上の注意
このトピックのサンプルコードでは、中国 (杭州) リージョンのリージョン ID
cn-hangzhouを使用します。デフォルトでは、パブリックエンドポイントを使用してバケット内のリソースにアクセスします。同じリージョン内の他の Alibaba Cloud サービスからバケットリソースにアクセスする場合は、内部エンドポイントを使用します。Object Storage Service (OSS) でサポートされているリージョンとエンドポイントの詳細については、「OSS のリージョンとエンドポイント」をご参照ください。このトピックでは、アクセス資格情報は環境変数から取得されます。アクセス資格情報の設定方法の詳細については、「アクセス資格情報の設定」をご参照ください。
オブジェクトのタグをクエリするには、
oss:GetObjectTagging権限が必要です。詳細については、「RAM ユーザーへのカスタムポリシーの付与」をご参照ください。
オブジェクトタグ付けでは、キーと値のペアを使用してオブジェクトを識別します。オブジェクトタグ付けの詳細については、OSS 開発者ガイドの「オブジェクトタグ付け」をご参照ください。
オブジェクトのタグをクエリする方法の詳細については、「GetObjectTagging」をご参照ください。
サンプルコード
次のコードは、バケット内のオブジェクトのタグをクエリする方法の例を示しています。
package main
import (
"context"
"flag"
"log"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss"
"github.com/aliyun/alibabacloud-oss-go-sdk-v2/oss/credentials"
)
// グローバル変数を定義します。
var (
region string // バケットが配置されているリージョン。
bucketName string // バケットの名前。
objectName string // オブジェクトの名前。
)
// コマンドラインパラメーターを初期化するために使用される init 関数を指定します。
func init() {
flag.StringVar(®ion, "region", "", "The region in which the bucket is located.")
flag.StringVar(&bucketName, "bucket", "", "The name of the bucket.")
flag.StringVar(&objectName, "object", "", "The name of the object.")
}
func main() {
// コマンドラインパラメーターを解析します。
flag.Parse()
// リージョンが指定されているかどうかを確認します。
if len(region) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, region required")
}
// バケットの名前が指定されているかどうかを確認します。
if len(bucketName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, bucket name required")
}
// オブジェクトの名前が指定されているかどうかを確認します。
if len(objectName) == 0 {
flag.PrintDefaults()
log.Fatalf("invalid parameters, object name required")
}
// デフォルト設定をロードし、資格情報プロバイダーとリージョンを指定します。
cfg := oss.LoadDefaultConfig().
WithCredentialsProvider(credentials.NewEnvironmentVariableCredentialsProvider()).
WithRegion(region)
// OSS クライアントを作成します。
client := oss.NewClient(cfg)
// オブジェクトのタグをクエリするリクエストを作成します。
getRequest := &oss.GetObjectTaggingRequest{
Bucket: oss.Ptr(bucketName), // バケットの名前。
Key: oss.Ptr(objectName), // オブジェクトの名前。
}
// クエリリクエストを作成し、結果を処理します。
getResult, err := client.GetObjectTagging(context.TODO(), getRequest)
if err != nil {
log.Fatalf("failed to get object tagging %v", err)
}
// タグの数を表示します。
log.Printf("get object tagging result:%#v\n", len(getResult.Tags))
}
リファレンス
オブジェクトのタグをクエリするために使用される完全なサンプルコードについては、GitHub をご参照ください。
オブジェクトタグをクエリするための API 操作の詳細については、「GetObjectTagging」をご参照ください。