HTTP headers and query string parameters for XML API
 
 
 The Cloud Storage XML API uses several standard HTTP headers as well as several extension (custom) HTTP headers. Several of the HTTP methods also support query string parameters. The headers and parameters are described below.
HTTP headers and query string parameters summary
The XML API uses the following standard HTTP headers:
The XML API uses the following extension (custom) HTTP headers:
The XML API uses the following query string parameters:
acl
Action
billing
compose
continuation-token
cors
customPlacementConfig
defaultObjectAcl
delimiter
encoding-type
encryption
encryptionConfig
fetch-owner
generation
generation-marker
key-marker
lifecycle list-type
location
logging
marker
Marker
max-keys
max-parts
max-uploads
MaxItems
object-lock
part-number-marker
partNumber
prefix
response-content-disposition
response-content-type
retention
start-after
Status
storageClass tagging
upload_id
upload-id-marker
uploadId
uploads
UserName
userProject
version-id-marker
versioning
versions
websiteConfig
X-Goog-Algorithm
X-Goog-Credential
X-Goog-Custom-Audit-KEY
X-Goog-Date
X-Goog-Expires
X-Goog-SignedHeaders
X-Goog-Signature
Standard HTTP headers
Authorization
A request header that contains a string used to authenticate requests.
- The authentication identifier Bearerfollowed by a valid OAuth 2.0 token.
- A valid signature header, as defined in the Simple migration documentation.
- The authentication identifier GOOG1orAWSfollowed byKEY_ACCESS_ID:V2_SIGNATURE.
Authorization: Bearer ya29.AHES6ZRVmB7fkLtd1XTmq6mo0S1wqZZi3-Lh_s- ... 
 To create a sample OAuth 2.0 access token for testing, you can use the OAuth 2.0 playground.
Note: If your requests are being routed
 through a proxy, you may need to check with your network administrator
 to ensure that the Authorization header containing your
 credentials is not stripped out by the proxy. Without the
 Authorization header, you receive a
 MissingSecurityHeader error and your request is rejected.
 For more information about accessing Cloud Storage through a proxy
 server, see the 
 Troubleshooting topic.
Cache-Control
A request and response header that specifies the cache-control setting.
Cache-Control: public, max-age=6000
 READ or FULL_CONTROL permission to
 AllUsers. If an object is accessible to all anonymous users
 and you do not specify a cache-control setting, Cloud Storage
 applies a cache-control setting of 3600 seconds. When serving via XML,
 Cloud Storage respects the cache-control of the object as set by
 its metadata.
 Content-Disposition
A request and response header that specifies presentational information about the data being transmitted.
Content-Disposition: attachment; filename=FILENAME
 attachment;filename=FILENAMEt,
 typically causing the web browser to open a "Save As..." dialog box.
 Content-Encoding
A request and response header that specifies the compression algorithm for an
object. This header is also used for requests that use a V4 signature in
the Authorization header and upload data in chunks.
aws-chunked
 Content-Encoding: gzip
 deflate), Cloud Storage preserves the header as
 object metadata, but does not
 compress or decompress the object.
 If an upload request uses Content-Encoding: aws-chunked,
 the request should authenticate using a
 V4 Signature, and
 its body should include chunked object data that meets the
 specification.
 The value aws-chunked is not stored as part of an object's
 metadata.
Content-Language
Language code of the content.
Content-Language: en
 Content-Length
The length (in bytes) of the request or response body.
Content-Length: 1234
 Content-Length header in a request, the request fails and
 Cloud Storage responds with a 411 Length Required status
 code.
 Content-MD5
The MD5 digest of the request body.
Content-MD5: iB94gawbwUSiZy5FuruIOQ==
 PUT operation.
 Content-Range
A request or response header that specifies a byte range.
Content-Range: bytes 456-987/1234
 When appearing in a response, the Content-Range header
 indicates the range of bytes being returned as a result of a request that
 included a Range header.
When included as part of a resumable
 upload request, Content-Range is used to query for the
 current position of the upload or as an indicator of the starting point
 of the block of data being uploaded in the current request.
Byte ranges are inclusive; that is, bytes 0-999 represent
 the first 1000 bytes in a file or object.
For additional details, particularly regarding download responses, see the specification.
Content-Type
The MIME type of the request or response.
Content-Type: text/html
 application/octet-stream 
 when it serves the object.
 Date
The date and time of the request or response.
Date: 2010年6月16日 11:11:11 GMT
 YYYYMMDD'T'HHMMSS'Z'.
 ETag
A response header that contains the entity tag of the object being accessed.
ETag: "39a59594290b0f9a30662a56d695b71d"ETag: "-CKicn4fknbUCEAE="
 Host
A request header that specifies the URI for Cloud Storage.
Host: storage.googleapis.com
 If-Match
A request header that specifies an entity tag (ETag).
If-Match: "881f7881ac1bc144a2672e45babb8839"
 If-Modified-Since
A request header that specifies a date and time.
If-Modified-Since: 2010年2月19日 22:04:23 GMT
 For more information about the If-Modified-Since header, see the specification. For more detail about HTTP date formats, see the specification, Section 7.1.1.2.
If-None-Match
A request header that specifies an entity tag (ETag).
If-None-Match: "881f7881ac1bc144a2672e45babb8839"
 If-Unmodified-Since
A request header that specifies a date and time.
If-Unmodified-Since: 2010年2月19日 22:04:23 GMT
 For more information about the If-Unmodified-Since header, see the specification. For more information about HTTP date formats, see the specification, Section 7.1.1.2.
Last-Modified
A response header that contains the date and time that the object was last modified.
Last-Modified: 2010年2月19日 22:04:23 GMT
 Location
A response header used for several purposes:
- In response to initiating a resumable upload it provides you with a session URI for a resumable upload operation.
- In response to completing a multipart upload it provides you with an endpoint for accessing the assembled object.
- In response to a Cookie-based authentication request it provides you with a unique web origin response URL for the request.
- In response to a JSON API download request made at a URL other than
www.googleapis.com/downloadit provides a redirect to the JSON API URL where the download can be made.
Location: https://example.storage.googleapis.com/?upload_id=tvA0...rot
 Location response header is returned when you initiate
 a resumable upload.
 Range
A request header indicating the range of bytes that you want returned, and a response header indicating the range of bytes that have been uploaded to the Cloud Storage system.
Range: bytes=0-1999 (first 2000 bytes)Range: bytes=-2000 (last 2000 bytes)Range: bytes=2000- (from byte 2000 to end of file)
 When included as a header in a request for object data, only the
 specified range of bytes for the object gets returned in the response
 body, which is useful when downloading an object in parallel requests or
 when resuming an interrupted download. A valid and successful request
 results in a
 206 Partial
 Content response code. Multiple byte ranges in a single request are
 not accepted, and in certain
 circumstances the Range request header is ignored.
When returned as part of a response associated with a resumable upload,
 Range indicates the number of bytes currently uploaded. You
 can subsequently use this information to
 continue
 the upload.
Byte ranges are inclusive. For example, bytes=0-999
 represent the first 1000 bytes in a file or object. For more information
 about this header, see the
 specification.
Transfer-Encoding
A request and response header that specifies if transfer-encoding had been applied to the message body.
chunked
 Transfer-Encoding: chunked
 This header specifies if the message body of a request or response
 has been chunked. If it is, content is received or served in a series of
 chunks, with the final chunk having a length of zero. If you specify
 Transfer-Encoding: Chunked, you don't need to specify a
 Content-Length. This can be useful if you don't know the
 length of the message body in advance, such as when performing a streaming
 upload.
In an upload request that uses Transfer-Encoding: Chunked
 and a V4 Signature
 in the Authorization header, the request must include a
 x-amz-decoded-content-length
 header. As a result, for such requests you must know the total length
 of the message body in advance, and you cannot use x-goog-*
 headers. In addition to a x-amz-decoded-content-length
 header, the request should also use the header
 Content-Encoding: aws-chunked.
For more details about Transfer-Encodings, see the specification. For more details about chunked transfer encoding, see the specification.
Extension (custom) HTTP headers
x-amz-decoded-content-length
A request header that indicates the size of an upload that uses chunked transfer encoding.
x-amz-decoded-content-length: 66560
 Authorization header uses the header
 Transfer-Encoding: Chunked. The value
 of the x-amz-decoded-content-length header must equal the
 total decoded size of the object data being uploaded in the request.
 Cloud Storage does not support a
 x-goog-decoded-content-length header.
 
 x-goog-acl
A request header that applies predefined ACLs to a bucket or object when you upload it or create it.
For buckets: project-private, private,
 public-read, public-read-write,
 authenticated-read
For objects: project-private, private,
 bucket-owner-read, bucket-owner-full-control,
 public-read, authenticated-read
x-goog-acl: private
 private ACL is applied.
 x-goog-allowed-resources
A request header that restricts the resources the request is allowed to act on.
x-goog-allowed-resources: ewogInJlc291cmNlcyI6IFsib3JnYW5pemF0aW9ucy8xMjM0NTY3ODkiLCAib3JnYW5pemF0aW9ucy8xMDExMTIxMzE0Il0sCiAib3B0aW9ucyI6ICJzdHJpY3QiCn0K
 x-goog-api-version
This header is deprecated and is not used.
x-goog-bucket-object-lock-enabled
A request header that enables object retention configurations for a new bucket.
true
 x-goog-bucket-object-lock-enabled: true
 true, objects added to the
 bucket can be configured to have a retention configuration. Values other
 than true cause this header to be ignored.
 x-goog-bucket-retention-period
A request header that adds a retention policy to a new bucket.
x-goog-bucket-retention-period: 32000
 x-goog-bypass-governance-retention
A request header that enables you to shorten, remove, or lock a retention configuration for an object.
true
 x-goog-bypass-governance-retention: true
 true in order to remove the retention configuration, make the
 retention configuration shorter, or set the mode of the retention
 configuration to COMPLIANCE. Note that a retention
 configuration cannot be removed or shortened if its mode is set to
 COMPLIANCE.
 x-goog-custom-audit-KEY
A request header that adds custom information to audit logs generated by Cloud Audit Logs.
KEY in the
 header name can contain up to 64 characters, including the
 x-goog-custom-audit prefix. The value can contain up to
 1,200 characters.
 x-goog-custom-audit-job: test-job-id
 metadata
 field of the protoPayload in the audit log entry.
 x-goog-component-count
A response header that indicates the number of components that make up a composite object.
x-goog-component-count: 32
 x-goog-content-length-range
A PUT request header. When used, Cloud Storage only accepts the
request if the size of the request's content is within the header's specified
range.
MIN,MAX pair
 x-goog-content-length-range: 0,256
 400 Bad Request code is
 returned in the response. If the x-goog-content-length-range
 is used in a request other than PUT, the header is silently
 ignored.
 x-goog-content-sha256
A request header that contains a hash of the request body.
UNSIGNED-PAYLOAD
 x-goog-content-sha256:e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855
 x-goog-content-sha256 must match the value you used for the
 payload
 portion of your canonical request.
 - For requests that initiate a
 resumable upload, the
 x-goog-content-sha256header is ignored, but the header is still required. To be consistent with the canonical request payload, you should setx-goog-content-sha256toUNSIGNED-PAYLOAD.
x-goog-copy-source
A request header that specifies the source bucket and object for a copy operation.
/BUCKET_NAME/OBJECT_NAME
 path
 x-goog-copy-source: travel-maps/paris.jpg
 You must have READ permission on the source object and at
 least WRITE permission on the destination bucket to use
 this header.
If the source and destination objects are the same (including the generation), the copy is treated as an update of the metadata. For details on controlling the update/replace behavior, see x-goog-metadata-directive.
x-goog-copy-source-generation
A request header that specifies the generation of the object to copy.
x-goog-copy-source-generation: 1360044097839000
 If the source and destination objects are the same (including the generation), the copy is treated as an update of the metadata. For details on controlling the update/replace behavior, see x-goog-metadata-directive.
x-goog-copy-source-if-generation-match
A request header that specifies the corresponding copy request will only be
executed if the source object x-goog-generation matches
the specified value. This header is only valid when used with
x-goog-copy-source.
x-goog-copy-source-if-generation-match: 1360044097835000
 For more information, see Request preconditions.
x-goog-copy-source-if-match
A request header that specifies the conditions for a copy operation.
x-goog-copy-source-if-match: 53fc311c15eda0a031809982ccf92aac
 x-goog-copy-source request header. If
 the ETag you specify with this request header matches the ETag of the
 source object, then the copy operation proceeds. If the ETag does not
 match, Cloud Storage returns a
 412 Precondition
 Failed error code.
 x-goog-copy-source-if-metageneration-match
A request header that specifies the corresponding request will only be allowed
if the metageneration of the source object matches the value of this header.
x-goog-copy-source-if-metageneration-match: 4
 If the source object metageneration matches the
 x-goog-copy-source-if-metageneration-match header, the
 request will be completed successfully and Cloud Storage returns
 a HTTP 200 OK status. If the metageneration does not match,
 Cloud Storage returns a
 412 Precondition
 Failed error code.
This value can only be used with
 x-goog-copy-source-if-generation-match
 or x-goog-copy-source-generation, and
 trying to use it without either of them will result in a
 HTTP 400 BadRequest Invalid Argument error code.
For more information, see Request preconditions.
x-goog-copy-source-if-modified-since
A request header that specifies the conditions for a copy operation.
x-goog-copy-source-if-modified-since: 2010年2月19日 14:05:04 GMT
 x-goog-copy-source request header. If the
 date and time you specify is earlier than the Last-Modified
 date of the source object, then the object is copied. If the date and time
 is later, Cloud Storage returns a
 412 Precondition
 Failed error code.
 For more information about the If-Modified-Since HTTP header (which, other than the copy source, applies to this use case), see the specification. For more information about HTTP date formats, see the specification, Section 7.1.1.2
x-goog-copy-source-if-none-match
A request header that specifies the conditions for a copy operation.
x-goog-copy-source-if-none-match: 53fc311c15eda0a031809982ccf92aac
 x-goog-copy-source request header. If the
 ETag you specify with this request header does not match the ETag of the
 source object, then the copy operation proceeds. If the ETag matches,
 Cloud Storage returns a
 412 Precondition
 Failed error code. For more information about the If-None-Match HTTP
 header (which, other than the copy source, applies to this use case), see
 the specification.
 x-goog-copy-source-if-unmodified-since
A request header that specifies the conditions for a copy operation.
x-goog-copy-source-if-unmodified-since: 2010年2月19日 14:05:04 GMT
 x-goog-copy-source request header. If the
 date and time you specify is later than the Last-Modified
 date of the source object, then the object is copied. If the date and time
 is earlier, Cloud Storage returns a
 412 Precondition
 Failed error code.
 For more information about the If-Unmodified-Since HTTP header (which, other than the copy source, applies to this use case), see the specification. For more information about HTTP date formats, see the specification, Section 7.1.1.2.
x-goog-custom-time
A request and response header for custom timestamp object metadata.
x-goog-custom-time: 2020年04月12日T23:20:50.52Z
 x-goog-date
A request header that specifies a time stamp for authenticated requests.
x-goog-date: 2010年2月19日 14:05:04 GMT
 YYYYMMDD'T'HHMMSS'Z'.
 x-goog-encryption-algorithm
A request and response header that specifies the encryption algorithm to use.
AES256
 x-goog-encryption-algorithm: AES256
 x-goog-encryption-key
A request header that specifies an AES-256 encryption key.
x-goog-encryption-key: NwbyGGmcKAX4FxGpOERG2Ap33m5NVOgmXznSGTEvG0I=
 x-goog-encryption-key-sha256
A request and response header that specifies the SHA256 hash of the encryption key.
x-goog-encryption-key-sha256: +eBzkZBt1Mj2CZx69L3c8yXoZB6DtRLlSvXMJB9JGIQ=
 x-goog-encryption-kms-key-name
A request and response header that specifies a Cloud KMS encryption key.
x-goog-encryption-kms-key-name: projects/my-project/locations/LOCATION_NAME/keyRings/KEYRING_NAME/cryptoKeys/KEY_NAME
 x-goog-expiration
A response header that specifies when the accessed object will be deleted, per the lifecycle configuration.
x-goog-expiration: Tue, 25 June 2013 00:00:00 GMT
 x-goog-generation
A response header that indicates which version of the object data you are accessing.
x-goog-generation: 1360044097835000
 For more information, see generation and metageneration numbers.
x-goog-if-generation-match
A request header that specifies the corresponding request is only allowed if the
x-goog-generation of the object matches the value of this header.
x-goog-if-generation-match: 1360044097835000
 x-goog-if-generation-match header, the request will be
 completed successfully and Cloud Storage returns a
 HTTP 200 OK status. If the generation does not match,
 Cloud Storage returns a HTTP 412 Precondition Failed
 error code.
 If you set the x-goog-if-generation-match header to 0,
 Cloud Storage only performs the specified request if the object
 does not currently exist. For example, you can perform a PUT request to
 create a new object with a x-goog-if-generation-match, and
 the object will only get created if it doesn't already exist as a live
 version. If the object exists, the request is aborted.
For more information, see Request preconditions.
x-goog-if-metageneration-match
A request header that specifies the corresponding request is only allowed if the
x-goog-metageneration of the object or bucket matches the value of this
header.
x-goog-if-metageneration-match: 4
 x-goog-if-metageneration-match header, the request proceeds
 as it normally would. If the metageneration does not match,
 Cloud Storage returns a HTTP 412 Precondition Failed
 error code.
 For object requests, this header should only be used in conjunction with x-goog-if-generation-match to ensure updates to metadata are in fact performed against the generation of the object you are planning to update and hence allows you to perform read-modify-write operations safely.
For more information, see Request preconditions.
x-goog-interop-list-objects-format
A request header that enables an interoperability fix to the GET bucket response.
enabled | disabled.
 x-goog-interop-list-objects-format: enabled
 Only use with the versions query
 parameter. Default is disabled.
If you specify enabled, an interoperable set of tags
 will be used.
If you specify disabled, the legacy set of tags will be
 used.
| enabledinteroperable tag | disabledlegacy tag | |
| Root XML tag | <ListVersionsResult> | <ListBucketResult> | 
| Key marker tag | <NextKeyMarker> | <NextMarker> | 
| Version Id marker tag | <NextVersionIdMarker> | <NextGenerationMarker> | 
| Version id tag | <VersionId> | <Generation> | 
x-goog-metadata-directive
A request header that specifies metadata handling during a copy operation.
Note that object ACLs, when present, are never copied. If applicable, the new
object receives ACLs specified in the x-goog-acl request header or
the default object ACLs set for the bucket that contains the new object.
COPY | REPLACE
 x-goog-metadata-directive: REPLACE
 Only used with the x-goog-copy-source request header.
 Default value is COPY.
If you specify COPY, the metadata of the source object is
 applied to the newly-created object.
If you specify REPLACE, the operation applies the metadata
 provided in the request to the newly-created object.
When copying an object such it rewrites the source object, you must
 include x-goog-metadata-directive: REPLACE.
 The header is optional in all other cases.
x-goog-metageneration
A response header that indicates which version of the object metadata you are accessing.
x-goog-metageneration: 1
 For more information, see generation and metageneration numbers.
x-goog-hash
A request and response header for expressing an object's MD5 and/or CRC32C base64-encoded checksums. As a request header for upload requests, the supplied hashes are validated against the values calculated by Cloud Storage.
md5=BASE64_ENCODED_MD5 or
 crc32c=BASE64_ENCODED_CRC32C. Specify CRC32c
 values in big-endian byte order. Also, note that
 HTTP considers comma
 separated header values as equivalent to separate headers with
 identical keys.
 x-goog-hash: crc32c=n03x6A==x-goog-hash: md5=Ojk9c3dhfxgoKVVHYwFbHQ==x-goog-hash: crc32c=n03x6A==,md5=Ojk9c3dhfxgoKVVHYwFbHQ==
 x-goog-meta-KEY
A request and response header that lets you define custom metadata for an object.
x-goog-meta-reviewer: jane
 x-goog-meta- prefix and then add the header and its
 associated value to your PUT or POST request. For example, if your objects
 are associated with various projects, you can add the project-specific
 information to your object metadata by creating several request headers,
 such as: x-goog-meta-project-name,
 x-goog-meta-project-number, and
 x-goog-meta-project-manager. You could then set a value for
 these request headers during a PUT or POST request as shown in the
 following example:
 PUT /kitten.jpg HTTP/1.1 Host: my-bucket.storage.googleapis.com Date: 2020年6月17日 11:11:11 GMT Content-Type: image/jpg Content-Length: 554 Authorization: Bearer 1/zVNpoQNsOSxZKqOZgckhpQ x-goog-meta-project-name: Sales Projections x-goog-meta-project-number: 878973 x-goog-meta-project-manager: W. Loman
x-goog-meta- headers are stored with an object and are
 always returned in a response header when you do a GET or HEAD request
 on an object.
x-goog-object-lock-mode
A request and response header for the mode associated with an object's retention configuration.
GOVERNANCE or COMPLIANCE
 x-goog-object-lock-mode: COMPLIANCE
 GOVERNANCE corresponds to the
 object's retention configuration being unlocked and a value of
 COMPLIANCE corresponds to the object's retention
 configuration being locked. If this header is specified in a request, the
 request must also include the
 x-goog-object-lock-retain-until-date header. This header gets
 returned as part of the response when you make a HEAD request or object
 download GET request if the requested object has a retention
 configuration.
 x-goog-object-lock-retain-until-date
A request and response header indicating the time until which an object subject to a retention configuration remains immutable.
x-goog-object-lock-retain-until-date: 2028年04月12日T23:20:50.52Z
 x-goog-object-lock-mode header.
 This header gets returned as part of the response when you make a HEAD
 request or object download GET request if the requested object has a
 retention configuration.
 x-goog-project-id
A request header that specifies which project you are working on.
x-goog-project-id: 000111222333x-goog-project-id: my-project-namex-goog-project-id: example.com:my-apps-for-work-project-name
 This header is optional for creating and listing buckets if you have set a default project for interoperable access.
x-goog-resumable
A request header that initiates a resumable upload operation.
x-goog-resumable: start
 x-goog-storage-class
A request and response header that indicates the storage class of an object.
STANDARD, NEARLINE, COLDLINE,
 ARCHIVE, MULTI_REGIONAL,
 REGIONAL
 
 x-goog-storage-class: NEARLINE
 PUT Object and
 POST Object requests in order to set an object to a storage
 class besides the default storage class of the associated bucket. The
 header is included in all GET Object responses.
 x-goog-stored-content-encoding
A response header that indicates the content encoding of the object as stored in Cloud Storage, independent of any server-driven negotiation that might occur for individual requests for the object.
identity.
 x-goog-stored-content-encoding: gzip
 content-encoding, then the value of this header is
 identity.
 x-goog-stored-content-length
A response header that indicates the content length (in bytes) of the object as stored in Cloud Storage, independent of any server-driven negotiation that might occur for individual requests for the object.
x-goog-stored-content-length: 350
 x-goog-user-project
A request header that specifies a user project to bill for access charges associated with the request.
x-goog-user-project: my-project
 x-guploader-uploadid
A response header returned for Cloud Storage requests.
x-guploader-uploadid: ADPycdvYczN-TgGGp1mvqlCLVKg2m0Cp9niWTV2kc8MLJG6W6Xw7aPMYj1YU8Pxskb5C9lUM8hVEtBG6DubMif3xhXkgTpfhpg
 x-guploader-uploadid header is a unique identifier
 provided in Cloud Storage responses. This value can be helpful
 when troubleshooting with Google Cloud support.
 
 Query string parameters
In the examples of query string parameters described in this section, the URIs
are not shown but are assumed to be relative to storage.googleapis.com. As
described in Request Endpoints, you can also specify the bucket name as
part of the hostname, for example,
BUCKET-NAME.storage.googleapis.com. If
you are specifying the bucket as part of the hostname, then do not include the
bucket name as part of the URI path. For example, the following are equivalent
for getting the ACL of an object:
- https://storage.googleapis.com/BUCKET-NAME/object-name?acl
- https://BUCKET-NAME.storage.googleapis.com/object-name?acl
AccessKeyId
A query string parameter that enables you to identify which HMAC key you want to update or delete.
/?Action=UpdateAccessKey&AccessKeyId=GOOG1EXAMPLE&Status=Inactive/?Action=DeleteAccessKey&AccessKeyId=GOOG1EXAMPLE
 AccessKeyId query string parameter allows you to
 specify which HMAC key you are updating or deleting. You must use
 AccessKeyId in conjunction with the
 Action query parameter. For information
 on how to retrieve the access ID for your HMAC key, see
 Getting
 HMAC key information.
 acl
A query string parameter that enables you to retrieve or change the access control list for a bucket or object.
/BUCKET_NAME?acl/BUCKET_NAME/OBJECT_NAME?acl
 Action
A query string parameter that enables you to identify which HMAC key operation to perform.
ListAccessKeys, CreateAccessKey,
 UpdateAccessKey, DeleteAccessKey
 /?Action=ListAccessKeys
 Action query string parameter allows you to specify
 which HMAC key operation to perform:
 list,
 create,
 update,
 or delete.
 billing
A query string parameter that allows you to enable, disable, or check the status of the Requester Pays feature for a bucket.
Enabled, Disabled.
 /BUCKET_NAME?billing
 GET Bucket,
 PUT Bucket. When used in a GET Bucket request,
 the current status of the Requester Pays feature is returned in the
 response body. When used in a PUT Bucket request, the request
 body should contain a <BillingConfiguration> element
 that specifies whether to enable or disable the feature. You cannot use
 any additional subresources with this query parameter. For more
 information on setting the Requester Pays feature using the XML API, see
 Set Bucket
 Metadata.
 compose
A query string parameter that enables you to compose a sequence of existing objects into a new composite object (used only with the XML API).
/BUCKET_NAME/OBJECT_NAME?compose
 continuation-token
A token that indicates where you want a list of objects to start.
NextContinuationToken value provided in the response
 body of a previous listing request.
 ?continuation-token=CglibHViLmdvc2g=
 continuation-token, the request must also
 include list-type=2 as a query string parameter.
 The continuation-token is an encoded field that marks the
 name and generation of the last object returned in a previous list
 request. The list of objects returned in the current request are those
 that are lexicographically greater than the object represented by
 continuation-token.
cors
A query string parameter that enables you to retrieve or change the Cross-Origin Resource Sharing (CORS) for a bucket.
/BUCKET_NAME?cors
 customPlacementConfig
A query string parameter that lets you set or retrieve the regions that make up a configurable dual-region. If the bucket was created as a region, multi-region, or predefined dual-region, the returned custom placement configuration is empty.
/BUCKET_NAME?customPlacementConfig
 defaultObjectAcl
A query string parameter that enables you to retrieve or change the default object access control list for a bucket.
/BUCKET_NAME?defaultObjectAcl
 delimiter
A character or group of characters that is used to restrict a list of objects or multipart uploads during a GET Bucket request.
/?delimiter=/
 The delimiter simplifies an objects or multipart uploads
 list for objects that use a directory-like naming scheme.
- When specified in an object listing, objects whose names do not
 contain the delimiter are returned as they normally would be in the
 Contentselements of the response. If an object name contains the delimiter, the portion of the object name up to and including the first instance of the delimiter appears in aCommonPrefixeselement of the response.
- When specified in a multipart upload listing, multipart uploads
 associated with objects whose names do not contain the delimiter are
 returned as they normally would be in the Uploadelements of the response. If an object name contains the delimiter, the portion of the object name up to and including the first instance of the delimiter appears in aCommonPrefixeselement of the response, and no multipart uploads associated with the object are returned in the listing.
You can use a delimiter in conjunction with a
 prefix parameter. In this case, the
 prefix limits results only to objects whose name matches
 prefix.
The delimiter is usually set to /, but it can
 be any sequence of characters. For an example of how to use a
 delimiter, see the
 delimiter
 example.
encoding-type
A query string parameter to URL-encode object names in responses to object listing requests.
url
 /bucket?encoding-type=url
 encryption
A query string parameter that enables you to retrieve an object's encryption information.
/object?encryption
 Encryption element. When the
 queried object is encrypted by a customer-managed encryption key, the
 Cloud Key Management Service key resource is returned in an Encryption
 element. In all other cases, an empty Encryption element is
 returned.
 You cannot use any additional subresources with this query parameter.
encryptionConfig
A query string parameter that enables you to set or retrieve the default customer-managed encryption key that a bucket uses.
/bucket?encryptionConfig
 EncryptionConfiguration element.
 Optional for PUT
 Bucket requests. When the request includes a customer-managed
 encryption key resource in the request body, that key becomes the default
 encryption key for the bucket. When the request includes an empty
 EncryptionConfiguration element, any existing default key is
 removed from the bucket.
fetch-owner
A boolean used in object listing requests to indicate if object owner information can be included in the response.
true or false
 ?fetch-owner=true
 fetch-owner, the request must also include
 list-type=2 as a query string parameter.
 The default value for fetch-owner is `false`. If the
 bucket used in the object listing request has
 Uniform bucket-level access
 enabled, fetch-owner=true has no effect, because no
 Owner values are set on objects in the bucket.
generation
A value that indicates which generation of the object to fetch.
?generation=1360887759327000
 generation query string parameter allows you to specify
 which version of the object to operate on.
 generation-marker
A value that indicates the generation number at which you want a list of objects to start.
?generation-marker=1360887759327000
 generation-marker, the request cannot include
 list-type=2 as a query string parameter.
 The generation-marker query string parameter is a starting
 point for paged listings on versioned buckets. Must be used in conjunction
 with marker, in order to fully specify the object and
 generation of where to start the listing after. Any object versions with
 greater than the specified generation-marker (including the
 live version if it has a greater generation) are returned in the list of
 objects, as are objects that are lexicographically greater than the
 marker.
key-marker
A string that indicates where you want a list of objects or ongoing multipart uploads to start.
?uploads&key-marker=myobject.jpeg
 When listing multipart uploads, the key-marker query
 string parameter is a string of Unicode characters that specifies which
 object you want a list of ongoing multipart uploads to begin after. The
 list of multipart uploads returned are those associated with objects that
 are lexicographically greater than key-marker.
When listing objects, key-marker is interchangeable with
 the marker query parameter.
lifecycle
A query string parameter that enables you to retrieve or change the lifecycle management policies for a bucket.
/BUCKET_NAME?lifecycle
 list-type
An indicator of which version of object listing your request is using.
1 or 2
 ?list-type=2
 list-type indicates which format is being used in the
 current request, as well as how the response should be handled.
 The default value for list-type is 1.
 For more information, see the List objects reference documentation.
location
A query string parameter that enables you to retrieve the location constraint for a bucket.
/BUCKET_NAME?location
 ?customPlacementConfig
 query parameter.
 
 logging
A query string parameter that enables you to retrieve or change the logging configuration for a bucket.
/BUCKET_NAME?logging
 marker
A string that indicates where you want a list of objects to start.
?marker=test
 marker, the request cannot include
 list-type=2 as a query string parameter.
 The marker query string parameter is a string of Unicode
 characters that specifies which object you want a list of objects to begin
 after. The list of objects returned are those that are lexicographically
 greater than the marker.
Marker
A page token that enables you to list subsequent pages of HMAC keys.
list response if
 IsTruncated is true.
 ?Action=ListAccessKeys&Marker=AERPALERN/NEXT/TOKEN
 Marker query string parameter is a continuation token,
 used to page through large result sets when listing HMAC keys for a given
 project. If IsTruncated is true in a previous
 listresponse, use the provided Marker token in
 subsequent list requests until IsTruncated is
 false. You must use Marker in conjunction with
 the Action  query parameter. For more
 information, see GET HMAC
 Key.
 max-keys
An integer that limits the number of objects returned in a single result "page".
?max-keys=100
 max-keys query string parameter is an integer that
 specifies the maximum number of objects you want returned in a list of
 objects. If a request can return more objects than max-keys
 allows, the IsTruncated response element contains a
 True value.
 The recommended upper value for max-keys is 1000 objects
 in a single response.
max-parts
A number that limits how many parts of a multipart upload can be returned in the response.
?uploadId=VALID_ID&max-parts=10
 max-parts query string parameter is an integer that
 specifies the maximum number of parts you want returned in a request to
 list the uploaded
 parts of a multipart upload. If max-parts=0, then the
 response omits all Part elements.
 If a request can return more parts than max-parts allows,
 the IsTruncated response element contains a
 True value.
max-uploads
A number that limits how many multipart uploads are returned in the response.
?uploads&max-uploads=10
 max-uploads query string parameter is an integer that
 specifies the maximum number of multipart uploads you want returned in a
 request to list the
 ongoing multipart uploads in a bucket. If max-uploads=0,
 then the response omits all Upload elements.
 If a request can return more uploads than max-uploads
 allows, the IsTruncated response element contains a
 True value.
MaxItems
An integer that limits the number of HMAC keys returned in a single result page.
?Action=ListAccessKeys&MaxItems=100
 MaxItems query string parameter is an integer that
 specifies the maximum number of HMAC keys returned in a single result
 page. If a request can return more keys than MaxItems allows,
 the IsTruncated response element contains a true
 value. You must use MaxItems in conjunction with the
 Action query parameter. The service may
 return fewer results than the specified maximum.
 object-lock
A query string parameter that enables you to retrieve the object retention configuration of a bucket.
?object-lock
 part-number-marker
A number that indicates where you want a list of multipart upload parts to start.
?uploadId=VALID_ID&part-number-marker=10
 part-number-marker query string parameter is an integer
 that specifies which part you want a
 list of parts
 to begin after. The list of parts returned are those that are greater
 than the part-number-marker.
 partNumber
A number that defines a piece of an XML API multipart upload.
partNumber query string parameter is used in a
 PUT Object
 request for a multipart upload. The partNumber defines
 where the current part is ordered in the overall object.
 prefix
A string that restricts a list of objects or multipart uploads based on the prefix of the object's name.
The prefix query string parameter is a string of Unicode
 characters that restricts the listing.
- For object listing, prefixrestricts the results to objects whose names begin with the specifiedprefixvalue.
- For multipart upload listing, prefixrestricts the results to multipart uploads whose associated object names begin with the specifiedprefixvalue.
You can use the prefix query string parameter in
 conjunction with the delimiter
 query string parameter to create a smaller subset of results.
response-content-disposition
A query string parameter that allows content-disposition to be overridden for authenticated GET requests.
?response-content-disposition=attachment%3B%20filename%3D%22foo%22
 For more information, see the specification.
response-content-type
A query string parameter that allows content-type to be overridden for authenticated GET requests.
?response-content-type=text%2Fhtml
 For more information, see the specification.
retention
A query string parameter that allows you to set, modify, or check the status of an existing object's retention configuration.
/OBJECT_NAME?retention
 GET Object,
 PUT Object. When used in a GET Object request,
 the object's current retention configuration is returned in the response
 body if it exists, and the requests fails with a
 404 Not Found response otherwise. When used in a
 PUT Object request, you must include an XML document in the
 request body that specifies the
 retention configuration.
 start-after
A string that indicates where you want a list of objects to start.
?start-after=test
 start-after, the request must also include
 list-type=2 as a query string parameter.
 The start-after query string parameter is a string of
 Unicode characters that specifies which object you want a list of objects
 to begin after. The list of objects returned are those that are
 lexicographically greater than the start-after. If you
 include continuation-token in your request as well,
 start-after is ignored.
Status
A query string parameter that allows you to enable or disable an HMAC key.
Active, Inactive
 ?Action=UpdateAccessKey&AccessKeyId=GOOG1EXAMPLE&Status=Inactive
 Status query string parameter allows you to change the
 status of an HMAC key between Active and
 Inactive. You must use Status in conjunction
 with the Action  and
 AccessKeyId  query parameters.
 storageClass
A query string parameter that enables you to set or retrieve the default storage class of a bucket.
STANDARD, NEARLINE,
 ARCHIVE, COLDLINE, MULTI_REGIONAL,
 REGIONAL, DURABLE_REDUCED_AVAILABILITY
 
 /BUCKET_NAME?storageClass
 GET Bucket,
 PUT Bucket. When used in a GET Bucket request,
 the default storage class of the specified bucket is returned in the
 response body. When used in a PUT Bucket request, the request
 body should contain a <StorageClass> element that
 specifies the default storage class you want to assign to the bucket. For
 more information on setting the default storage class of a bucket using
 the XML API, see Set
 Bucket Metadata.
 tagging
A query string parameter that enables you to set or retrieve the labels applied to a bucket.
key:value pair.
 /BUCKET_NAME?tagging
 GET Bucket,
 PUT Bucket. When used in a GET Bucket request,
 the labels applied to the specified bucket are returned in the response
 body. When used in a PUT Bucket request, the request body
 should contain a <Tagging> element that specifies the
 labels you want to apply to the bucket. For more information on applying
 labels using the XML API, see
 Set Bucket
 Metadata.
 upload_id
A query string parameter that specifies that upload ID for a resumable upload
operation. The upload_id is part of the session URI, but you should save the
entire session URI because it uniquely defines the request URI for subsequent
resumable uploads operations. The session URI is obtained from the
Location response header.
/?upload_id=tvA0ExBntDaOKdxL46u1NkHxNb...B2Uowrot
 If you use an expired upload ID in a request, you will receive a 404 Not Found status code. In this case, you will have to re-initiate the resumable upload, obtain a new upload ID, and start the upload from the beginning using the new upload ID.
The upload ID is bound to the location it was created, so if you create in one location and use it in another location, your performance will suffer.
The upload ID is a Bearer token, meaning possession of this token acts as an authenticator. Thus, you should be careful not to leak upload IDs.
upload-id-marker
A value that indicates the upload at which you want a list of multipart uploads to start.
NextUploadIdMarker returned in a previous listing request.
 ?uploads&key-marker=myobject.jpeg&upload-id-marker=VXBsb2FkIElEIGZvciBlbHZpbmcncyBteS1tb3ZpZS5tMnRzIHVwbG9hZA
 upload-id-marker query string parameter marks the
 starting point for a list of ongoing multipart uploads in a bucket. In
 order to fully specify an object and upload, upload-id-marker
 can only be used in conjunction with key-marker. Any ongoing
 multipart uploads for key-marker with an
 upload-id greater than upload-id-marker are
 returned in the list, and any ongoing multipart uploads for objects that
 are lexicographically greater than key-marker are also
 returned in the list.
 uploadId
A string that identifies the multipart upload the request applies to.
UploadId returned in a request to initiate a
 multipart upload.
 /?uploadId=VXBsb2FkIElEIGZvciBlbHZpbmcncyBteS1tb3ZpZS5tMnRzIHVwbG9hZA
 uploadId query string parameter is used to identify a
 multipart upload after you have
 initiated the
 upload. For example, you use an uploadId when making a
 PUT Object request to
 upload a part for
 an object.
 A multipart upload ID differs from a resumable upload ID in several important ways:
- A multipart upload ID never expires. It remains valid until you either abort the upload or complete the upload.
- A multipart upload ID is not an authenticator. You must still include valid authorization in requests that use a multipart upload ID.
uploads
A query string parameter used to initiate an XML API multipart upload or retrieve a list of multipart uploads in progress for a bucket.
/OBJECT_NAME?uploads
 POST Object request, the request initiates
 an XML multipart upload and returns an upload ID, which you use in
 subsequent PUT requests to upload the data.
 When used in a GET Bucket request, the request returns
 a list of multipart uploads in the bucket that have been initiated, but
 that have not yet been completed or aborted.
UserName
A query string parameter that enables you to identify the service account for which you want to create, update, or list an HMAC key.
/?Action=CreateAccessKey&UserName=serviceAccount@proj.iam.gserviceaccount.com
 UserName is required for creating an HMAC key and optional
 for updating a key or listing keys associated with a project. You must use
 UserName in conjunction with the
 Action  query parameter.
 userProject
A query string parameter that specifies a project ID to bill for access charges associated with the request.
?userProject=example-project
 userProject is used, for example, when
 making requests to buckets that have
 Requester Pays enabled.
 Generally, XML requests that require a project ID should supply one in
 the x-goog-user-project
 header instead of the userProject parameter.
version-id-marker
A value that indicates the generation number at which you want a list of objects to start.
?version-id-marker=1360887759327000
 version-id-marker, the request cannot include
 list-type=2 as a query string parameter.
 The version-id-marker query string parameter is a starting
 point for paged listings on versioned buckets. Must be used in conjunction
 with key-marker, in order to fully specify the object and
 generation of where to start the listing after. Any object versions with
 greater than the specified version-id-marker (including the
 live version if it has a greater generation) are returned in the list of
 objects, as are objects that are lexicographically greater than the
 key-marker.
versioning
A query string parameter that enables you to retrieve or change versioning configuration of a bucket.
/OBJECT_NAME?versioning
 versions
A query string parameter that enables you to retrieve all generation of objects in a versioned bucket.
/BUCKET_NAME?versions=True
 websiteConfig
A query string parameter that enables you to retrieve or change a bucket's website configuration.
/BUCKET_NAME?websiteConfig
 X-Goog-Algorithm
A query string parameter to determine the V4 signed URL algorithm.
GOOG4-RSA-SHA256GOOG4-HMAC-SHA256AWS4-HMAC-SHA256
 X-Goog-Credential
A query string parameter to determine the credential type used.
Service_Account_Email/Date/Region/goog4_requestGoogle_HMAC_Access_Key_ID/Date/Region/goog4_requestAWS_HMAC_Access_Key_ID/Date/Region/aws4_request
 example%40example-project.iam.gserviceaccount.com%2F20181026%2Fus-central1%2Fstorage%2Fgoog4_requestUsing HMAC:
GOOGTS7C7FUP3AIRVJTE2BCD%2F20181026%2Fus-central1%2Fstorage%2Fgoog4_request
 X-Goog-Custom-Audit-KEY
A query string parameter to pass custom metadata to be included in audit logs.
x-goog-custom-audit-KEY=VALUE
 KEY can contain up to 64 characters, while each
 VALUE can contain up to 1,200 characters. Each KEY
 can only contain alphanumeric characters and dashes. Each request can
 contain up to 4 audit entries.
 Add custom
 information to audit logs.
 X-Goog-Date (Query Parameter)
The date and time the signed URL became usable.
?X-Goog-Date=20181026T181309Z
 X-Goog-Expires
A query string parameter to determine how long a V4 signed URL is active.
?X-Goog-Expires=900
 X-Goog-SignedHeaders
A query string parameter to determine the headers signed in a V4 signed URL.
?X-Goog-SignedHeaders=host?X-Goog-SignedHeaders=host,x-goog-acl
 X-Goog-Signature
A query string parameter with the value of a V4 signed URL signature.
?X-Goog-Signature=247a2aa45f169edf4d187d54e7cc46e4731b1e6273242c4f4c39a1d2507a0e58706e25e3a85a7dbb891d62afa8496def8e260c1db863d9ace85ff0a184b894b117fe46d1225c82f2aa19efd52cf21d3e2022b3b868dcc1aca2741951ed5bf3bb25a34f5e9316a2841e8ff4c530b22ceaa1c5ce09c7cbb5732631510c20580e61723f5594de3aea497f195456a2ff2bdd0d13bad47289d8611b6f9cfeef0c46c91a455b94e90a66924f722292d21e24d31dcfb38ce0c0f353ffa5a9756fc2a9f2b40bc2113206a81e324fc4fd6823a29163fa845c8ae7eca1fcf6e5bb48b3200983c56c5ca81fffb151cca7402beddfc4a76b133447032ea7abedc098d2eb14a7
 Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2025年10月24日 UTC.