全部文档
当前文档

暂无内容

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

文档中心

追加上传(Go)

最近更新时间:2024-05-10 14:24:23

追加上传文件

以下代码用于追加上传文件:

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"
    "os"
)

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>"
    // 填写上传文件路径
    filePath := "/Users/test/demo.txt"
    // 打开文件
    fd, err := os.Open(filePath)
    if err != nil {
        panic(err)
    }
    // 追加上传对象
    resp, err := client.AppendObject(&s3.AppendObjectInput{
        Bucket:   aws.String(bucket),           // 存储空间名称,必填
        Key:      aws.String(key),              // 对象的Key,必填
        Position: aws.Long(0),                  // 追加上传的起始位置,必填
        Body:     fd,                           // 要上传的文件,必填
        ACL:      aws.String(s3.ACLPublicRead), // 对象访问权限,非必填
        Metadata: map[string]*string{
            "Key": aws.String("MetadataValue"), // 设置对象元数据,非必填
        },
    })
    if err != nil {
        panic(err)
    }
    fmt.Println("结果:\n", awsutil.StringValue(resp))
}

追加上传加密文件

KS3托管密钥的服务器端加密(SSE-S3)

以下代码用于追加上传加密文件,加密方式为:KS3托管密钥的服务器端加密(SSE-S3)。

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"
    "os"
)

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>"
    // 填写上传文件路径
    filePath := "/Users/test/demo.txt"
    // 打开文件
    fd, err := os.Open(filePath)
    if err != nil {
        panic(err)
    }
    // 追加上传对象,使用KS3托管密钥的服务器端加密 (SSE-S3)
    resp, err := client.AppendObject(&s3.AppendObjectInput{
        Bucket:               aws.String(bucket),   // 存储空间名称,必填
        Key:                  aws.String(key),      // 对象的Key,必填
        Position:             aws.Long(0),          // 追加上传的起始位置,必填
        Body:                 fd,                   // 要上传的文件,必填
        ServerSideEncryption: aws.String("AES256"), // 使用KS3托管密钥的服务器端加密,合法值:AES256
    })
    if err != nil {
        panic(err)
    }
    fmt.Println("结果:\n", awsutil.StringValue(resp))
}

客户提供加密密钥的服务器端加密(SSE-C)

以下代码用于追加上传加密文件,加密方式为:客户提供加密密钥的服务器端加密(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"
    "os"
)

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>"
    // 填写上传文件路径
    filePath := "/Users/test/demo.txt"
    // 打开文件
    fd, err := os.Open(filePath)
    if err != nil {
        panic(err)
    }
    // 填写您用于加密的密钥,密钥长度支持16/24/32位
    SSECustomerKey := "<encryption_key>"
    // 追加上传对象,使用客户提供的加密密钥的服务器端加密(SSE-C)
    resp, err := client.AppendObject(&s3.AppendObjectInput{
        Bucket:               aws.String(bucket),                                 // 存储空间名称,必填
        Key:                  aws.String(key),                                    // 对象的Key,必填
        Position:             aws.Long(0),                                        // 追加上传的起始位置,必填
        Body:                 fd,                                                 // 要上传的文件,必填
        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))
}

追加上传文件对应的API文档:Append Object

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

纯净模式

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