设置对象属性

更新时间: 2019-03-14 10:05

您可以在上传对象时设置对象属性。对象属性包含对象长度、对象MIME类型、对象MD5值(用于校验)、对象存储类型、对象自定义元数据。对象属性可以在多种上传方式下(流式上传、文件上传、分段上传),或复制对象时进行设置。

对象属性详细说明见下表:


名称

描述

默认值

对象长度(Content-Length)

上传对象的长度,超过流/文件的长度会截断。

流/文件实际长度

对象MIME类型(Content-Type)

对象的MIME类型,定义对象的类型及网页编码,决定浏览器将以什么形式、什么编码读取对象。

binary/octet-stream

对象MD5值(Content-MD5)

对象数据的MD5值(经过Base64编码),提供给OBS服务端,校验数据完整性。



对象存储类型

对象的存储类型,不同的存储类型可以满足客户业务对存储性能、成本的不同诉求。默认与桶的存储类型保持一致,可以设置为与桶的存储类型不同。



对象自定义元数据

用户对上传到桶中对象的自定义属性描述,以便对对象进行自定义管理。


设置对象长度

您可以通过PutObjectInput.ContentLength或者PutFileInput.ContentLength来设置对象长度。以下代码展示如何设置对象长度:

  1. // 引入依赖包
  2. import (
  3. "fmt"
  4. "obs"
  5. )
  6.  
  7. var ak = "*** Provide your Access Key ***"
  8. var sk = "*** Provide your Secret Key ***"
  9. var endpoint = "https://your-endpoint"
  10.  
  11. // 创建ObsClient结构体
  12. var obsClient, _ = obs.New(ak, sk, endpoint)
  13.  
  14. func main() {
  15. input := &obs.PutFileInput{}
  16. input.Bucket = "bucketname"
  17. input.Key = "objectkey"
  18. input.SourceFile = "localfile"
  19. // 只上传100个字节
  20. input.ContentLength = 100
  21. output, err := obsClient.PutFile(input)
  22. if err == nil {
  23. fmt.Printf("RequestId:%s\n", output.RequestId)
  24. } else if obsError, ok := err.(obs.ObsError); ok {
  25. fmt.Printf("Code:%s\n", obsError.Code)
  26. fmt.Printf("Message:%s\n", obsError.Message)
  27. }
  28. }

设置对象MIME类型

您可以通过PutObjectInput.ContentType或者PutFileInput.ContentType来设置对象MIME类型。以下代码展示如何设置对象MIME类型:

  1. // 引入依赖包
  2. import (
  3. "fmt"
  4. "obs"
  5. )
  6.  
  7. var ak = "*** Provide your Access Key ***"
  8. var sk = "*** Provide your Secret Key ***"
  9. var endpoint = "https://your-endpoint"
  10.  
  11. // 创建ObsClient结构体
  12. var obsClient, _ = obs.New(ak, sk, endpoint)
  13.  
  14. func main() {
  15. input := &obs.PutFileInput{}
  16. input.Bucket = "bucketname"
  17. input.Key = "objectkey"
  18. input.SourceFile = "localimage.jpg"
  19. // 上传图片
  20. input.ContentType = "image/jpeg"
  21. output, err := obsClient.PutFile(input)
  22. if err == nil {
  23. fmt.Printf("RequestId:%s\n", output.RequestId)
  24. } else if obsError, ok := err.(obs.ObsError); ok {
  25. fmt.Printf("Code:%s\n", obsError.Code)
  26. fmt.Printf("Message:%s\n", obsError.Message)
  27. }
  28. }

设置对象属性 - 图1 说明:

如果不设置对象MIME类型,SDK会根据上传对象的后缀名自动判断对象MIME类型,如.xml判断为application/xml文件;.html判断为text/html文件。

设置对象MD5值

您可以通过PutObjectInput.ContentMD5或者PutFileInput.ContentMD5来设置对象MD5值。以下代码展示如何设置对象MD5值:

  1. // 引入依赖包
  2. import (
  3. "fmt"
  4. "obs"
  5. )
  6.  
  7. var ak = "*** Provide your Access Key ***"
  8. var sk = "*** Provide your Secret Key ***"
  9. var endpoint = "https://your-endpoint"
  10.  
  11. // 创建ObsClient结构体
  12. var obsClient, _ = obs.New(ak, sk, endpoint)
  13.  
  14. func main() {
  15. input := &obs.PutFileInput{}
  16. input.Bucket = "bucketname"
  17. input.Key = "objectkey"
  18. input.SourceFile = "localfile"
  19. // 设置MD5
  20. input.ContentMD5 = "your md5 which should be encoded by base64"
  21. output, err := obsClient.PutFile(input)
  22. if err == nil {
  23. fmt.Printf("RequestId:%s\n", output.RequestId)
  24. } else if obsError, ok := err.(obs.ObsError); ok {
  25. fmt.Printf("Code:%s\n", obsError.Code)
  26. fmt.Printf("Message:%s\n", obsError.Message)
  27. }
  28. }

设置对象属性 - 图2 说明:

  • 对象数据的MD5值必须经过Base64编码。
  • OBS服务端会将该MD5值与对象数据计算出的MD5值进行对比,如果不匹配则上传失败,返回HTTP 400错误。
  • 如果不设置对象的MD5值,OBS服务端会忽略对对象数据的MD5值校验。

设置对象存储类型

您可以通过PutObjectInput.StorageClass或者PutFileInput.StorageClass来设置对象存储类型。以下代码展示如何设置对象存储类型:

  1. // 引入依赖包
  2. import (
  3. "fmt"
  4. "obs"
  5. )
  6.  
  7. var ak = "*** Provide your Access Key ***"
  8. var sk = "*** Provide your Secret Key ***"
  9. var endpoint = "https://your-endpoint"
  10.  
  11. // 创建ObsClient结构体
  12. var obsClient, _ = obs.New(ak, sk, endpoint)
  13.  
  14. func main() {
  15. input := &obs.PutFileInput{}
  16. input.Bucket = "bucketname"
  17. input.Key = "objectkey"
  18. input.SourceFile = "localfile"
  19. // 设置对象存储类型为归档存储
  20.  
  21. input.StorageClass = obs.StorageClassCold
  22. output, err := obsClient.PutFile(input)
  23. if err == nil {
  24. fmt.Printf("RequestId:%s\n", output.RequestId)
  25. } else if obsError, ok := err.(obs.ObsError); ok {
  26. fmt.Printf("Code:%s\n", obsError.Code)
  27. fmt.Printf("Message:%s\n", obsError.Message)
  28. }
  29. }

设置对象属性 - 图3 说明:

  • 如果不设置,对象的存储类型默认与桶的存储类型保持一致。
  • 对象的存储类型分为三类,其含义与桶存储类型一致。
  • 下载归档存储类型的对象前必须将其取回。

设置对象自定义元数据

您可以通过PutObjectInput.Metadata或者PutFileInput.Metadata参数来设置对象自定义元数据。以下代码展示如何设置对象自定义元数据:

  1. // 引入依赖包
  2. import (
  3. "fmt"
  4. "obs"
  5. "strings"
  6. )
  7.  
  8. var ak = "*** Provide your Access Key ***"
  9. var sk = "*** Provide your Secret Key ***"
  10. var endpoint = "https://your-endpoint"
  11.  
  12. // 创建ObsClient结构体
  13. var obsClient, _ = obs.New(ak, sk, endpoint)
  14.  
  15. func main() {
  16. input := &obs.PutObjectInput{}
  17. input.Bucket = "bucketname"
  18. input.Key = "objectkey"
  19. input.Body = strings.NewReader("Hello OBS")
  20. input.Metadata = map[string]string{"property1": "property-value1", "property2": "property-value2"}
  21. output, err := obsClient.PutObject(input)
  22. if err == nil {
  23. fmt.Printf("RequestId:%s\n", output.RequestId)
  24. } else if obsError, ok := err.(obs.ObsError); ok {
  25. fmt.Printf("Code:%s\n", obsError.Code)
  26. fmt.Printf("Message:%s\n", obsError.Message)
  27. }
  28. }

设置对象属性 - 图4 说明:

  • 在上面设置对象自定义元数据示例代码中,用户自定义了一个名称为“property1”,值为“property-value1”的元数据和一个名称为“property2”,值为“property-value2”的元数据。
  • 一个对象可以有多个元数据,总大小不能超过8KB。
  • 对象的自定义元数据可以通过ObsClient.GetObjectMetadata获取,参见获取对象元数据
  • 使用ObsClient.GetObject下载对象时,对象的自定义元数据也会同时下载。

父主题:上传对象