HeadObject接口用于获取某个文件(Object)的元数据。使用此接口不会返回文件内容。
版本控制
在请求参数中不指定versionId的情况下执行HeadObject操作,默认获取当前版本Object的元数据。如果当前版本Object为删除标记,则返回404 NoSuchKey。
在请求参数中指定versionId的情况下执行HeadObject操作,返回指定版本Object的元数据。不支持在请求参数中指定删除标记的versionId,否则返回405 MethodNotAllowed。
请求语法
HEAD /ObjectName HTTP/1.1
Host: BucketName.oss-cn-hangzhou.aliyuncs.com
Date: GMT Date
Authorization: SignatureValue
请求头
名称 | 类型 | 是否必选 | 描述 |
If-Modified-Since | 字符串 | 否 | 如果传入参数中的时间早于实际修改时间,则返回200 OK和Object Meta;否则返回304 Not Modified。 默认值:无 |
If-Unmodified-Since | 字符串 | 否 | 如果传入参数中的时间等于或者晚于文件实际修改时间,则返回200 OK和Object Meta;否则返回412 Precondition Failed。 默认值:无 |
If-Match | 字符串 | 否 | 如果传入期望的ETag和Object的 ETag匹配,则返回200 OK和Object Meta;否则返回412 precondition failed。 默认值:无 |
If-None-Match | 字符串 | 否 | 如果传入期望的ETag值和Object的ETag不匹配,则返回200 OK和Object Meta;否则返回304 Not Modified。 默认值:无 |
此接口还包含Host、Date等公共请求头。更多信息,请参见公共请求头(Common Request Headers)。
响应头
如果请求的文件类型为软链接,则各个响应头的信息说明如下:
Content-Length、ETag、x-oss-storage-class以及Content-Md5均为目标文件的元数据。
Last-Modified取软链接的最后修改时间及目标文件的最后修改时间两者中的较大值。
其他响应头均表示软链接的元数据。
名称 | 类型 | 描述 |
x-oss-meta-* | 字符串 | 以x-oss-meta-为前缀的参数作为用户自定义meta header。当用户在PutObject时设置了以x-oss-meta-为前缀的自定义meta,则响应中会包含这些自定义meta。 |
非x-oss-meta-开头的自定义header | 字符串 | 当用户在PutObject时,自定义一些非x-oss-meta为前缀的Header,如x-oss-persistent-headers:key1:base64_encode(value1),key2:base64_encode(value2).... ,响应中会增加相应的自定义Header。 |
x-oss-server-side-encryption | 字符串 | 如果该Object进行服务器端熵编码加密存储的,则在响应头中会返回此参数,其值表明该Object的服务器端加密算法。 |
x-oss-server-side-encryption-key-id | 字符串 | 如果用户在创建Object时使用了服务端加密,且加密方法为KMS,则响应中会包含此Header,表示加密所使用的用户KMS key ID。 |
x-oss-storage-class | 字符串 | 表示Object的存储类型,分别为标准存储类型(Standard)、低频访问存储类型(IA)、归档存储类型(Archive)、冷归档存储类型(ColdArchive)以及深度冷归档存储类型(DeepColdArchive)。 更多信息,请参见存储类型介绍。 |
x-oss-object-type | 字符串 | 表示Object的类型。
|
x-oss-next-append-position | 字符串 | 对于Appendable类型的Object会返回此Header,指明下一次请求应当提供的position。 |
x-oss-hash-crc64ecma | 字符串 | 表示该Object的64位CRC值。该64位CRC根据ECMA-182标准计算得出。 对OSS支持CRC64校验前创建的Object,调用HeadObject接口时可能不会返回此响应头。 |
x-oss-transition-time | 字符串 | Object通过生命周期规则转储为冷归档或者深度冷归档存储类型的时间。 说明
|
x-oss-expiration | 字符串 | 配置了生命周期规则的Bucket中Object的过期时间。
|
x-oss-restore | 字符串 | 如果Object存储类型为Archive、ColdArchive或者DeepColdArchive,且您已提交Restore请求,则响应头中会以x-oss-restore返回该Object的Restore状态,分如下几种情况:
|
x-oss-process-status | 字符串 | 当用户通过轻量消息队列SMQ创建OSS事件通知后,在进行请求OSS相关操作时如果有匹配的事件通知规则,则响应中会携带这个Header,值为经过Base64编码JSON格式的事件通知结果。 |
x-oss-request-charged | 字符串 | 当Object所属的Bucket被设置为请求者付费模式,且请求者不是Bucket的拥有者时,响应中将携带此Header,值为requester。 |
Content-Md5 | 字符串 |
|
Last-Modified | 字符串 | Object最后一次修改的日期,格式为HTTP 1.1协议中规定的GMT时间。 说明
|
Access-Control-Allow-Origin | 字符串 | 当Object所在的Bucket配置了CORS规则,且请求的Origin满足指定的CORS规则时会在响应中包含这个Origin。 |
Access-Control-Allow-Methods | 字符串 | 当Object所在的Bucket配置了CORS规则,且请求的Access-Control-Request-Method满足指定的CORS规则时会在响应中包含允许的Methods。 |
Access-Control-Max-Age | 字符串 | 当Object所在的Bucket配置了CORS规则,且请求满足Bucket配置的CORS规则时会在响应中包含MaxAgeSeconds。 |
Access-Control-Allow-Headers | 字符串 | 当Object所在的Bucket配置了CORS规则,且请求满足指定的CORS规则时会在响应中包含这些Headers。 |
Access-Control-Expose-Headers | 字符串 | 表示允许访问客户端JavaScript程序的headers列表。当Object所在的Bucket配置了CORS规则,且请求满足指定的CORS规则时会在响应中包含ExposeHeader。 |
x-oss-tagging-count | 字符串 | 对象关联的标签个数。仅当用户有读取标签权限时返回。 |
此接口还包含ETag、x-oss-request-id等公共响应头。更多信息,请参见公共响应头(Common Response Headers)。
示例
未启用版本控制
请求示例
HEAD /oss.jpg HTTP/1.1 Host: oss-example.oss-cn-hangzhou.aliyuncs.com Date: Fri, 7 Aug 2020 07:32:52 GMT Authorization: OSS qn6q**************:77Dv****************
返回示例(当Object为文件时)
HTTP/1.1 200 OK x-oss-request-id: 559CC9BDC755F95A6448**** x-oss-object-type: Normal x-oss-storage-class: Archive Date: Fri, 7 Aug 2020 07:32:52 GMT Last-Modified: Fri, 24 Feb 2012 06:07:48 GMT ETag: "fba9dede5f27731c9771645a3986****" Content-Length: 344606 Content-Type: image/jpg Connection: keep-alive Server: AliyunOSS
返回示例(当Object为目录时)
HTTP/1.1 200 OK x-oss-request-id: 559CC9BDC755F95A6448**** x-oss-object-type: Normal x-oss-storage-class: Standard Date: Wed, 31 Mar 2021 07:32:52 GMT Last-Modified: Tue, 30 Mar 2021 06:07:48 GMT ETag: "null" Content-Length: 0 Content-Type: application/x-directory Connection: keep-alive Server: AliyunOSS
请求对象指定版本(启用版本控制)
请求示例
HEAD /example?versionId=CAEQNRiBgICb8o6D0BYiIDNlNzk5NGE2M2Y3ZjRhZTViYTAxZGE0ZTEyMWYy**** Host: versioning-test.oss-cn-hangzhou.aliyuncs.com Date: Fri, 7 Aug 2020 06:27:12 GMT Authorization: OSS qn6q**************:77Dv****************
返回示例
HTTP/1.1 200 OK x-oss-versionId: CAEQNRiBgICb8o6D0BYiIDNlNzk5NGE2M2Y3ZjRhZTViYTAxZGE0ZTEyMWYy**** x-oss-request-id: 5CAC3B40B7AEADE01700**** x-oss-object-type: Normal x-oss-storage-class: Archive Date: Fri, 7 Aug 2020 06:27:12 GMT Last-Modified: Fri, 7 Aug 2020 06:27:12 GMT ETag: "A082B659EF78733A5A042FA253B1****" Content-Length: 481827 Content-Type: text/html Connection: keep-alive Server: AliyunOSS
请求对象最新版本(启用版本控制)
请求示例
HEAD /example HTTP/1.1 Host: versioning-test.oss-cn-hangzhou.aliyuncs.com Date: Fri, 7 Aug 2020 06:27:12 GMT Authorization: OSS qn6q**************:77Dv****************
返回示例
HTTP/1.1 200 OK x-oss-versionId: CAEQMxiBgMCZov2D0BYiIDY4MDllOTc2YmY5MjQxMzdiOGI3OTlhNTU0ODIx**** x-oss-request-id: 5CAC3B40B7AEADE01700**** x-oss-object-type: Normal x-oss-storage-class: Archive Date: Fri, 7 Aug 2020 06:27:12 GMT Last-Modified: Fri, 7 Aug 2020 06:27:12 GMT ETag: "3663F7B0B9D3153F884C821E7CF4****" Content-Length: 485859 Content-Type: text/html Connection: keep-alive Server: AliyunOSS
提交Restore请求但Restore未完成
请求示例
HEAD /oss.jpg HTTP/1.1 Host: oss-archive-example.oss-cn-hangzhou.aliyuncs.com Date: Fri, 7 Aug 2020 07:32:52 GMT Authorization: OSS qn6q**************:77Dv****************
返回示例
HTTP/1.1 200 OK x-oss-request-id: 58F71A164529F18D7F00**** x-oss-object-type: Normal x-oss-storage-class: Archive x-oss-restore: ongoing-request="true" Date: Fri, 7 Aug 2020 07:32:52 GMT Last-Modified: Fri, 7 Aug 2020 06:07:48 GMT ETag: "fba9dede5f27731c9771645a3986****" Content-Length: 344606 Content-Type: image/jpg Connection: keep-alive Server: AliyunOSS
提交Restore请求且Restore已完成
请求示例
HEAD /oss.jpg HTTP/1.1 Host: oss-archive-example.oss-cn-hangzhou.aliyuncs.com Date: Fri, 7 Aug 2020 09:35:51 GMT Authorization: OSS qn6q**************:77Dv****************
返回示例
HTTP/1.1 200 OK x-oss-request-id: 58F725344529F18D7F00**** x-oss-object-type: Normal x-oss-storage-class: Archive x-oss-restore: ongoing-request="false", expiry-date="Sun, 16 Apr 2017 08:12:33 GMT" Date: Fri, 7 Aug 2020 09:35:51 GMT Last-Modified: Fri, 7 Aug 2020 06:07:48 GMT ETag: "fba9dede5f27731c9771645a3986****" Content-Length: 344606
使用服务端加密SSE-OSS
请求示例
HEAD /oss.jpg HTTP/1.1 Host: oss-example.oss-cn-hangzhou.aliyuncs.com Date: Fri, 7 Aug 2020 07:32:52 GMT Authorization: OSS qn6q**************:77Dv****************
返回示例
HTTP/1.1 200 OK x-oss-request-id: 559CC9BDC755F95A6448**** x-oss-object-type: Normal x-oss-storage-class: Archive x-oss-server-side-encryption: AES256 Date: Fri, 7 Aug 2020 07:32:52 GMT Last-Modified: Fri, 7 Aug 2020 06:07:48 GMT ETag: "fba9dede5f27731c9771645a3986****" Content-Length: 344606 Content-Type: image/jpg Connection: keep-alive Server: AliyunOSS
使用服务器端加密SSE-KMS
请求示例
HEAD /oss.jpg HTTP/1.1 Host: oss-example.oss-cn-hangzhou.aliyuncs.com Date: Fri, 7 Aug 2020 07:32:52 GMT Authorization: OSS qn6q**************:77Dv****************
返回示例
HTTP/1.1 200 OK x-oss-request-id: 559CC9BDC755F95A64485981 x-oss-object-type: Normal x-oss-storage-class: Archive x-oss-server-side-encryption: KMS x-oss-server-side-encryption-key-id: 9468da86-3509-4f8d-a61e-6eab1eac**** Date: Fri, 7 Aug 2020 07:32:52 GMT Last-Modified: Fri, 7 Aug 2020 06:07:48 GMT ETag: "fba9dede5f27731c9771645a3986****" Content-Length: 344606 Content-Type: image/jpg Connection: keep-alive Server: AliyunOSS
错误码
错误码 | HTTP 状态码 | 描述 |
NoSuchKey | 404 | 请求的文件不存在。 |
SymlinkTargetNotExist | 404 | 请求的文件类型为软链接。 |
InvalidTargetType | 400 | 请求的文件类型为软链接,且对应的目标文件类型也为软链接。 |
NotModified | 304 | 返回该错误的可能原因如下:
|
PreconditionFailed | 412 | 返回该错误的可能原因如下:
|