使用Multipart Upload模式传输数据前,必须先调用该接口来通知OSS初始化一个Multipart Upload事件。该接口会返回一个OSS服务器创建的全局唯一的Upload ID,用于标识本次Multipart Upload事件。用户可以根据这个ID来发起相关的操作,如中止Multipart Upload、查询Multipart Upload等。
请求语法POST /ObjectName?uploads HTTP/1.1
Host: BucketName.oss-cn-hangzhou.aliyuncs.com
Date: GMT date
Authorization: SignatureValue
请求参数(Request Parameters)
Initiate Multipart Upload时,可以通过encoding-type对返回结果中的Key进行编码。
请求Header
响应元素(Response Elements)
细节分析
- 该操作计算认证签名的时候,需要加“?uploads”到CanonicalizedResource中。
- 初始化Multipart Upload请求,支持如下标准的HTTP请求头:Cache-Control,Content- Disposition,Content-Encoding,Content-Type,Expires,以及以“x-oss-meta-”开头的用户自定义Headers。具体含义请参见PUT Object接口。
- 初始化Multipart Upload请求,并不会影响已经存在的同名object。
- 服务器收到初始化Multipart Upload请求后,会返回一个XML格式的请求体。该请求体内有三个元素:Bucket,Key和UploadID。请记录下其中的UploadID,以用于后续的Multipart相关操作。
- 初始化Multipart Upload请求时,若设置了x-oss-server-side-encryption Header,则在响应头中会返回该Header,并且在上传的每个part时,服务端会自动对每个part进行熵编码加密存储,目前OSS服务器端只支持256位高级加密标准(AES256),指定其他值会返回400和相应的错误提示:InvalidEncryptionAlgorithmError;在上传每个part时不必再添加x-oss-server-side-encryption 请求头,若指定该请求头则OSS会返回400和相应的错误提示:InvalidArgument。
示例
[backcolor=transparent]请求示例:
POST /multipart.data?uploads HTTP/1.1
Host: oss-example.oss-cn-hangzhou.aliyuncs.com
Date: Wed, 22 Feb 2012 08:32:21 GMT
Authorization: OSS qn6qrrqxo2oawuk53otfj byc:/cluRFtRwMTZpC2hTj4F67AGdM4=
[backcolor=transparent]返回示例:
HTTP/1.1 200 OK
Content-Length: 230
Server: AliyunOSS
Connection: keep-alive
x-oss-request-id: 42c25703-7503-fbd8-670a-bda01eaec618
Date: Wed, 22 Feb 2012 08:32:21 GMT
Content-Type: application/xml
<?xml version="1.0" encoding="UTF-8"?>
<InitiateMultipartUploadResult xmlns=”http://doc.oss-cn-hangzhou.aliyuncs.com”>
<Bucket> multipart_upload</Bucket>
<Key>multipart.data</Key>
<UploadId>0004B9894A22E5B1888A1E29F8236E2D</UploadId>
</InitiateMultipartUploadResult>