全部文档
当前文档

暂无内容

如果没有找到您期望的内容,请尝试其他搜索词

文档中心

管理文件元数据(Go)

最近更新时间:2024-05-10 14:22:57

修改文件元数据信息

以下代码用于修改文件元数据信息:

package main

import (
    "fmt"
    "github.com/ks3sdklib/aws-sdk-go/aws"
    "github.com/ks3sdklib/aws-sdk-go/aws/awsutil"
    "github.com/ks3sdklib/aws-sdk-go/aws/credentials"
    "github.com/ks3sdklib/aws-sdk-go/service/s3"
)

func main() {
    // 创建访问凭证,请将<AccessKeyID>与<SecretAccessKey>替换成真正的值
    cre := credentials.NewStaticCredentials("<AccessKeyID>", "<SecretAccessKey>", "")
    // 创建S3Client,更多配置项请查看Go-SDK初始化文档
    client := s3.New(&aws.Config{
       Credentials: cre,                          // 访问凭证
       Region:      "BEIJING",                    // 填写您的Region
       Endpoint:    "ks3-cn-beijing.ksyuncs.com", // 填写您的Endpoint
    })
    // 填写存储空间名称
    bucket := "<bucket_name>"
    // 填写对象的key
    key := "<object_key>"
    // 填写对象元数据信息
    metadata := make(map[string]*string)
    metadata["metakey1"] = aws.String("metavalue1")
    metadata["metakey2"] = aws.String("metavalue2")

    // 修改文件元数据信息
    resp, err := client.CopyObject(&s3.CopyObjectInput{
       Bucket:            aws.String(bucket),                   // 存储空间名称,必填
       Key:               aws.String(key),                      // 对象的key,必填
       CopySource:        aws.String("/" + bucket + "/" + key), // 源对象路径,空间名称与对象key的组合,通过斜杠分隔('/'),必填
       MetadataDirective: aws.String("REPLACE"),                // 指定如何设置目标Object的对象元数据:COPY(默认):复制源Object的对象元数据到目标Object;REPLACE:忽略源Object的对象元数据,直接采用请求中指定的对象元数据,必填
       Metadata:          metadata,                             // 文件元数据信息,必填
    })
    if err != nil {
       panic(err)
    }
    fmt.Println("结果:\n", awsutil.StringValue(resp))
}

获取文件元数据信息

以下代码用于获取文件元数据信息:

package main

import (
    "fmt"
    "github.com/ks3sdklib/aws-sdk-go/aws"
    "github.com/ks3sdklib/aws-sdk-go/aws/awsutil"
    "github.com/ks3sdklib/aws-sdk-go/aws/credentials"
    "github.com/ks3sdklib/aws-sdk-go/service/s3"
)

func main() {
    // 创建访问凭证,请将<AccessKeyID>与<SecretAccessKey>替换成真正的值
    cre := credentials.NewStaticCredentials("<AccessKeyID>", "<SecretAccessKey>", "")
    // 创建S3Client,更多配置项请查看Go-SDK初始化文档
    client := s3.New(&aws.Config{
       Credentials: cre,                          // 访问凭证
       Region:      "BEIJING",                    // 填写您的Region
       Endpoint:    "ks3-cn-beijing.ksyuncs.com", // 填写您的Endpoint
    })
    // 填写存储空间名称
    bucket := "<bucket_name>"
    // 填写对象的key
    key := "<object_key>"
    // 获取文件元数据信息
    resp, err := client.HeadObject(&s3.HeadObjectInput{
       Bucket: aws.String(bucket), // 存储空间名称,必填
       Key:    aws.String(key),    // 对象的key,必填
    })
    if err != nil {
       panic(err)
    }
    fmt.Println("结果:\n", awsutil.StringValue(resp))
}

获取加密文件元数据信息

以下代码用于获取加密文件元数据信息,加密方式为:客户提供加密密钥的服务器端加密(SSE-C)。

package main

import (
    "fmt"
    "github.com/ks3sdklib/aws-sdk-go/aws"
    "github.com/ks3sdklib/aws-sdk-go/aws/awsutil"
    "github.com/ks3sdklib/aws-sdk-go/aws/credentials"
    "github.com/ks3sdklib/aws-sdk-go/service/s3"
    "github.com/ks3sdklib/aws-sdk-go/service/s3/s3util"
)

func main() {
    // 创建访问凭证,请将<AccessKeyID>与<SecretAccessKey>替换成真正的值
    cre := credentials.NewStaticCredentials("<AccessKeyID>", "<SecretAccessKey>", "")
    // 创建S3Client,更多配置项请查看Go-SDK初始化文档
    client := s3.New(&aws.Config{
        Credentials: cre,                          // 访问凭证
        Region:      "BEIJING",                    // 填写您的Region
        Endpoint:    "ks3-cn-beijing.ksyuncs.com", // 填写您的Endpoint
    })
    // 填写存储空间名称
    bucket := "<bucket_name>"
    // 填写对象的key
    key := "<object_key>"
    // 填写您用于加密的密钥,密钥长度支持16/24/32位
    SSECustomerKey := "<encryption_key>"
    // 获取文件元数据信息,使用客户提供的加密密钥的服务器端加密(SSE-C)
    resp, err := client.HeadObject(&s3.HeadObjectInput{
        Bucket:               aws.String(bucket),                              // 存储空间名称,必填
        Key:                  aws.String(key),                                 // 对象的key,必填
        SSECustomerAlgorithm: aws.String("AES256"),                            // 客户端提供的加密算法,合法值:AES256
        SSECustomerKey:       aws.String(s3util.GetBase64Str(SSECustomerKey)), // 客户端提供的加密密钥进行Base64编码后的值
        SSECustomerKeyMD5:    aws.String(s3util.GetBase64MD5Str(SSECustomerKey)),    // 客户端提供的通过BASE64编码的通过128位MD5加密的密钥的MD5值
    })
    if err != nil {
        panic(err)
    }
    fmt.Println("结果:\n", awsutil.StringValue(resp))
}

文档导读
纯净模式常规模式

纯净模式

点击可全屏预览文档内容
文档反馈