更新时间:2026-04-08 GMT+08:00
分享

上传对象-基于表单上传(Go SDK)

功能说明

基于表单上传是使用HTML表单形式上传对象到指定桶中,对象最大不能超过5GB。可以通过如下步骤进行表单上传:

  1. 使用ObsClient.CreateBrowserBasedSignature生成用于鉴权的请求参数。
  2. 准备表单HTML页面。
  3. 将生成的请求参数填入HTML页面。
  4. 选择本地文件,进行表单上传。

使用SDK生成的用于鉴权的请求参数包括两个:

接口约束

  • 您必须是桶拥有者或拥有上传对象的权限,才能上传对象。建议使用IAM或桶策略进行授权,如果使用IAM则需授予obs:object:PutObject权限,如果使用桶策略则需授予PutObject权限。相关授权方式介绍可参见OBS权限控制概述,配置方式详见使用IAM自定义策略配置对象策略
  • OBS支持的Region与Endpoint的对应关系,详细信息请参见地区与终端节点
  • HTML表单中的policy,signature的值均是从ObsClient.createPostSignature的返回结果中获取。

方法定义

func (obsClient ObsClient) CreateBrowserBasedSignature(input *CreateBrowserBasedSignatureInput) (output *CreateBrowserBasedSignatureOutput, err error)

请求参数说明

表1 请求参数列表

参数名称

参数类型

是否必选

描述

input

*CreateBrowserBasedSignatureInput

必选

参数解释:

表单上传请求参数,详情参考CreateBrowserBasedSignatureInput

表2 CreateBrowserBasedSignatureInput

参数名称

参数类型

是否可选

描述

Bucket

string

可选

参数解释

桶名。

约束限制:

  • 桶的名字需全局唯一,不能与已有的任何桶名称重复,包括其他用户创建的桶。
  • 桶命名规则如下:
    • 3~63个字符,数字或字母开头,支持小写字母、数字、“-”、“.”。
    • 禁止使用IP地址。
    • 禁止以“-”或“.”开头及结尾。
    • 禁止两个“.”相邻(如:“my..bucket”)。
    • 禁止“.”和“-”相邻(如:“my-.bucket”和“my.-bucket”)。
  • 同一用户在同一个区域多次创建同名桶不会报错,创建的桶属性以第一次请求为准。

默认取值:

Key

string

可选

参数解释:

对象名。对象名是对象在存储桶中的唯一标识。对象名是对象在桶中的完整路径,路径中不包含桶名。

例如,您对象的访问地址为examplebucket.obs.cn-north-4.myhuaweicloud.com/folder/test.txt 中,对象名为folder/test.txt。

取值范围:

长度大于0且不超过1024的字符串。

默认取值:

Expires

int

可选

参数解释:

表单上传鉴权的过期时间。

取值范围:

正整数。单位:秒。

默认取值:

300

FormParams

map[string]string

可选

参数解释:

除key,policy,signature外,表单上传时的其他参数。

取值范围:

acl、cache-control、content-type、content-disposition、content-encoding、expires

默认取值:

返回结果说明

表3 返回结果

参数名称

参数类型

描述

output

*CreateBrowserBasedSignatureOutput

参数解释:

接口返回信息,详情参考CreateBrowserBasedSignatureOutput

err

error

参数解释:

接口返回错误信息。

表4 CreateBrowserBasedSignatureOutput

参数名称

参数类型

描述

OriginPolicy

string

参数解释:

Policy未经过base64之前的值,仅用于校验。示例如下:

{"expiration":"2023-09-12T12:52:59Z","conditions":[{"content-type":"text/plain"},{"bucket":"examplebucket"},{"key":"example/objectname"},]}"

默认取值:

Policy

string

参数解释:

表单中的policy,已经base64之后的值。示例如下:

eyJleHBpcmF0aW9uIjoiMjAyMy0wOS0xMlQxMjo1Mjo1OVoiLCJjb25kaXRpb25zIjpbeyJjb250ZW50LXR5cGUiOiJ0ZXh0L3BsYWluIn0seyJidWNrZXQiOiJleGFtcGxlYnVja2V0In0seyJrZXkiOiJleGFtcGxlL29iamVjdG5hbWUifSxdfQ==

默认取值:

Signature

string

参数解释:

表单中的signature。示例如下:

g0jQr4v9VWd1Q2FOFDG6LGfV9Cw=

默认取值:

代码示例

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
// 引入依赖包
import (
       "fmt"
       "obs"
)


func main() {
    //推荐通过环境变量获取AKSK,这里也可以使用其他外部引入方式传入,如果使用硬编码可能会存在泄露风险。
    //您可以登录访问管理控制台获取访问密钥AK/SK,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html。
    ak := os.Getenv("AccessKeyID")
    sk := os.Getenv("SecretAccessKey")
    // 【可选】如果使用临时AK/SK和SecurityToken访问OBS,同样建议您尽量避免使用硬编码,以降低信息泄露风险。您可以通过环境变量获取访问密钥AK/SK,也可以使用其他外部引入方式传入。
    // securityToken := os.Getenv("SecurityToken")
    // endpoint填写Bucket对应的Endpoint, 这里以华北-北京四为例,其他地区请按实际情况填写。
    endPoint := "https://obs.cn-north-4.myhuaweicloud.com"
    // 创建obsClient实例
    // 如果使用临时AKSK和SecurityToken访问OBS,需要在创建实例时通过obs.WithSecurityToken方法指定securityToken值。
    obsClient, _:= obs.New(ak, sk, endPoint/*, obs.WithSecurityToken(securityToken)*/)

    input := &obs.CreateBrowserBasedSignatureInput{}
    // 设置表单参数
    formParams := make(map[string]string)
    // 设置对象ACL为公共读
    formParams["x-obs-acl"] = string(obs.AclPublicRead)
    // 设置对象MIME类型
    formParams["content-type"] = "text/plain"
    input.FormParams = formParams
    // 设置表单上传请求有效期,单位:秒
    input.Expires = 3600
    output, _ := obsClient.CreateBrowserBasedSignature(input)
    // 获取表单上传请求参数
    fmt.Printf("Policy:%s\n", output.Policy)
    fmt.Printf("Signature:%s\n", output.Signature)
}

示例表单HTML代码如下:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    </head>
    <body>
        <form action="http://bucketname.your-endpoint/" method="post" enctype="multipart/form-data">
            <p>
                Object key
            </p>            
            <!-- 对象名 -->
            <input type="text" name="key" value="objectname" />
            <p>
                ACL
            </p>
            <!-- 对象ACL权限 -->
            <input type="text" name="x-obs-acl" value="public-read" />
            <p>
                Content-Type
            </p>
            <!-- 对象MIME类型 -->
            <input type="text" name="content-type" value="text/plain" />
            <p>            
                <!-- policy的base64编码值 -->
                <input type="hidden" name="policy" value="*** Provide your policy ***" />
                <!-- AK -->
                <input type="hidden" name="AccessKeyId" value="*** Provide your access key ***"/>
                <!-- 签名串信息 -->
                <input type="hidden" name="signature" value="*** Provide your signature ***"/>
                <input name="file" type="file" />
                <input name="submit" value="Upload" type="submit" />
            </p>
        </form>
    </body>
</html>

相关链接

  • 关于上传对象-POST上传的API说明,请参见POST上传
  • 上传对象过程中返回的错误码含义、问题原因及处理措施可参考OBS错误码
  • 上传对象常见问题请参见上传对象失败

相关文档