Class GetObjectRequest
- java.lang.Object
-
- software.amazon.awssdk.core.SdkRequest
-
- software.amazon.awssdk.awscore.AwsRequest
-
- software.amazon.awssdk.services.s3.model.S3Request
-
- software.amazon.awssdk.services.s3.model.GetObjectRequest
-
- All Implemented Interfaces:
SdkPojo
,ToCopyableBuilder<GetObjectRequest.Builder,GetObjectRequest>
@Generated("software.amazon.awssdk:codegen") public final class GetObjectRequest extends S3Request implements ToCopyableBuilder<GetObjectRequest.Builder,GetObjectRequest>
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static interface
GetObjectRequest.Builder
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description String
bucket()
The bucket name containing the object.static GetObjectRequest.Builder
builder()
ChecksumMode
checksumMode()
To retrieve the checksum, this mode must be enabled.String
checksumModeAsString()
To retrieve the checksum, this mode must be enabled.boolean
equals(Object obj)
boolean
equalsBySdkFields(Object obj)
String
expectedBucketOwner()
The account ID of the expected bucket owner.<T> Optional<T>
getValueForField(String fieldName, Class<T> clazz)
int
hashCode()
String
ifMatch()
Return the object only if its entity tag (ETag) is the same as the one specified in this header; otherwise, return a412 Precondition Failed
error.Instant
ifModifiedSince()
Return the object only if it has been modified since the specified time; otherwise, return a304 Not Modified
error.String
ifNoneMatch()
Return the object only if its entity tag (ETag) is different from the one specified in this header; otherwise, return a304 Not Modified
error.Instant
ifUnmodifiedSince()
Return the object only if it has not been modified since the specified time; otherwise, return a412 Precondition Failed
error.String
key()
Key of the object to get.Integer
partNumber()
Part number of the object being read.String
range()
Downloads the specified byte range of an object.RequestPayer
requestPayer()
Returns the value of the RequestPayer property for this object.String
requestPayerAsString()
Returns the value of the RequestPayer property for this object.String
responseCacheControl()
Sets theCache-Control
header of the response.String
responseContentDisposition()
Sets theContent-Disposition
header of the response.String
responseContentEncoding()
Sets theContent-Encoding
header of the response.String
responseContentLanguage()
Sets theContent-Language
header of the response.String
responseContentType()
Sets theContent-Type
header of the response.Instant
responseExpires()
Sets theExpires
header of the response.Map<String,SdkField<?>>
sdkFieldNameToField()
List<SdkField<?>>
sdkFields()
static Class<? extends GetObjectRequest.Builder>
serializableBuilderClass()
String
sseCustomerAlgorithm()
Specifies the algorithm to use when decrypting the object (for example,AES256
).String
sseCustomerKey()
Specifies the customer-provided encryption key that you originally provided for Amazon S3 to encrypt the data before storing it.String
sseCustomerKeyMD5()
Specifies the 128-bit MD5 digest of the customer-provided encryption key according to RFC 1321.GetObjectRequest.Builder
toBuilder()
String
toString()
Returns a string representation of this object.String
versionId()
Version ID used to reference a specific version of the object.-
Methods inherited from class software.amazon.awssdk.awscore.AwsRequest
overrideConfiguration
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface software.amazon.awssdk.utils.builder.ToCopyableBuilder
copy
-
-
-
-
Method Detail
-
bucket
public final String bucket()
The bucket name containing the object.
Directory buckets - When you use this operation with a directory bucket, you must use virtual-hosted-style requests in the format
Bucket-name.s3express-zone-id.region-code.amazonaws.com
. Path-style requests are not supported. Directory bucket names must be unique in the chosen Zone (Availability Zone or Local Zone). Bucket names must follow the formatbucket-base-name--zone-id--x-s3
(for example,amzn-s3-demo-bucket--usw2-az1--x-s3
). For information about bucket naming restrictions, see Directory bucket naming rules in the Amazon S3 User Guide.Access points - When you use this action with an access point for general purpose buckets, you must provide the alias of the access point in place of the bucket name or specify the access point ARN. When you use this action with an access point for directory buckets, you must provide the access point name in place of the bucket name. When using the access point ARN, you must direct requests to the access point hostname. The access point hostname takes the form AccessPointName-AccountId.s3-accesspoint.Region.amazonaws.com. When using this action with an access point through the Amazon Web Services SDKs, you provide the access point ARN in place of the bucket name. For more information about access point ARNs, see Using access points in the Amazon S3 User Guide.
Object Lambda access points - When you use this action with an Object Lambda access point, you must direct requests to the Object Lambda access point hostname. The Object Lambda access point hostname takes the form AccessPointName-AccountId.s3-object-lambda.Region.amazonaws.com.
Object Lambda access points are not supported by directory buckets.
S3 on Outposts - When you use this action with S3 on Outposts, you must direct requests to the S3 on Outposts hostname. The S3 on Outposts hostname takes the form
AccessPointName-AccountId.outpostID.s3-outposts.Region.amazonaws.com
. When you use this action with S3 on Outposts, the destination bucket must be the Outposts access point ARN or the access point alias. For more information about S3 on Outposts, see What is S3 on Outposts? in the Amazon S3 User Guide.- Returns:
- The bucket name containing the object.
Directory buckets - When you use this operation with a directory bucket, you must use virtual-hosted-style requests in the format
Bucket-name.s3express-zone-id.region-code.amazonaws.com
. Path-style requests are not supported. Directory bucket names must be unique in the chosen Zone (Availability Zone or Local Zone). Bucket names must follow the formatbucket-base-name--zone-id--x-s3
(for example,amzn-s3-demo-bucket--usw2-az1--x-s3
). For information about bucket naming restrictions, see Directory bucket naming rules in the Amazon S3 User Guide.Access points - When you use this action with an access point for general purpose buckets, you must provide the alias of the access point in place of the bucket name or specify the access point ARN. When you use this action with an access point for directory buckets, you must provide the access point name in place of the bucket name. When using the access point ARN, you must direct requests to the access point hostname. The access point hostname takes the form AccessPointName-AccountId.s3-accesspoint.Region.amazonaws.com. When using this action with an access point through the Amazon Web Services SDKs, you provide the access point ARN in place of the bucket name. For more information about access point ARNs, see Using access points in the Amazon S3 User Guide.
Object Lambda access points - When you use this action with an Object Lambda access point, you must direct requests to the Object Lambda access point hostname. The Object Lambda access point hostname takes the form AccessPointName-AccountId.s3-object-lambda.Region.amazonaws.com.
Object Lambda access points are not supported by directory buckets.
S3 on Outposts - When you use this action with S3 on Outposts, you must direct requests to the S3 on Outposts hostname. The S3 on Outposts hostname takes the form
AccessPointName-AccountId.outpostID.s3-outposts.Region.amazonaws.com
. When you use this action with S3 on Outposts, the destination bucket must be the Outposts access point ARN or the access point alias. For more information about S3 on Outposts, see What is S3 on Outposts? in the Amazon S3 User Guide.
-
ifMatch
public final String ifMatch()
Return the object only if its entity tag (ETag) is the same as the one specified in this header; otherwise, return a
412 Precondition Failed
error.If both of the
If-Match
andIf-Unmodified-Since
headers are present in the request as follows:If-Match
condition evaluates totrue
, and;If-Unmodified-Since
condition evaluates tofalse
; then, S3 returns200 OK
and the data requested.For more information about conditional requests, see RFC 7232.
- Returns:
- Return the object only if its entity tag (ETag) is the same as the one specified in this header;
otherwise, return a
412 Precondition Failed
error.If both of the
If-Match
andIf-Unmodified-Since
headers are present in the request as follows:If-Match
condition evaluates totrue
, and;If-Unmodified-Since
condition evaluates tofalse
; then, S3 returns200 OK
and the data requested.For more information about conditional requests, see RFC 7232.
-
ifModifiedSince
public final Instant ifModifiedSince()
Return the object only if it has been modified since the specified time; otherwise, return a
304 Not Modified
error.If both of the
If-None-Match
andIf-Modified-Since
headers are present in the request as follows:If-None-Match
condition evaluates tofalse
, and;If-Modified-Since
condition evaluates totrue
; then, S3 returns304 Not Modified
status code.For more information about conditional requests, see RFC 7232.
- Returns:
- Return the object only if it has been modified since the specified time; otherwise, return a
304 Not Modified
error.If both of the
If-None-Match
andIf-Modified-Since
headers are present in the request as follows:If-None-Match
condition evaluates tofalse
, and;If-Modified-Since
condition evaluates totrue
; then, S3 returns304 Not Modified
status code.For more information about conditional requests, see RFC 7232.
-
ifNoneMatch
public final String ifNoneMatch()
Return the object only if its entity tag (ETag) is different from the one specified in this header; otherwise, return a
304 Not Modified
error.If both of the
If-None-Match
andIf-Modified-Since
headers are present in the request as follows:If-None-Match
condition evaluates tofalse
, and;If-Modified-Since
condition evaluates totrue
; then, S3 returns304 Not Modified
HTTP status code.For more information about conditional requests, see RFC 7232.
- Returns:
- Return the object only if its entity tag (ETag) is different from the one specified in this header;
otherwise, return a
304 Not Modified
error.If both of the
If-None-Match
andIf-Modified-Since
headers are present in the request as follows:If-None-Match
condition evaluates tofalse
, and;If-Modified-Since
condition evaluates totrue
; then, S3 returns304 Not Modified
HTTP status code.For more information about conditional requests, see RFC 7232.
-
ifUnmodifiedSince
public final Instant ifUnmodifiedSince()
Return the object only if it has not been modified since the specified time; otherwise, return a
412 Precondition Failed
error.If both of the
If-Match
andIf-Unmodified-Since
headers are present in the request as follows:If-Match
condition evaluates totrue
, and;If-Unmodified-Since
condition evaluates tofalse
; then, S3 returns200 OK
and the data requested.For more information about conditional requests, see RFC 7232.
- Returns:
- Return the object only if it has not been modified since the specified time; otherwise, return a
412 Precondition Failed
error.If both of the
If-Match
andIf-Unmodified-Since
headers are present in the request as follows:If-Match
condition evaluates totrue
, and;If-Unmodified-Since
condition evaluates tofalse
; then, S3 returns200 OK
and the data requested.For more information about conditional requests, see RFC 7232.
-
key
public final String key()
Key of the object to get.
- Returns:
- Key of the object to get.
-
range
public final String range()
Downloads the specified byte range of an object. For more information about the HTTP Range header, see https://www.rfc-editor.org/rfc/rfc9110.html#name-range.
Amazon S3 doesn't support retrieving multiple ranges of data per
GET
request.- Returns:
- Downloads the specified byte range of an object. For more information about the HTTP Range header, see https://www.rfc-editor.org/rfc/rfc9110.html#
name-range.
Amazon S3 doesn't support retrieving multiple ranges of data per
GET
request.
-
responseCacheControl
public final String responseCacheControl()
Sets the
Cache-Control
header of the response.- Returns:
- Sets the
Cache-Control
header of the response.
-
responseContentDisposition
public final String responseContentDisposition()
Sets the
Content-Disposition
header of the response.- Returns:
- Sets the
Content-Disposition
header of the response.
-
responseContentEncoding
public final String responseContentEncoding()
Sets the
Content-Encoding
header of the response.- Returns:
- Sets the
Content-Encoding
header of the response.
-
responseContentLanguage
public final String responseContentLanguage()
Sets the
Content-Language
header of the response.- Returns:
- Sets the
Content-Language
header of the response.
-
responseContentType
public final String responseContentType()
Sets the
Content-Type
header of the response.- Returns:
- Sets the
Content-Type
header of the response.
-
responseExpires
public final Instant responseExpires()
Sets the
Expires
header of the response.- Returns:
- Sets the
Expires
header of the response.
-
versionId
public final String versionId()
Version ID used to reference a specific version of the object.
By default, the
GetObject
operation returns the current version of an object. To return a different version, use theversionId
subresource.-
If you include a
versionId
in your request header, you must have thes3:GetObjectVersion
permission to access a specific version of an object. Thes3:GetObject
permission is not required in this scenario. -
If you request the current version of an object without a specific
versionId
in the request header, only thes3:GetObject
permission is required. Thes3:GetObjectVersion
permission is not required in this scenario. -
Directory buckets - S3 Versioning isn't enabled and supported for directory buckets. For this API operation, only the
null
value of the version ID is supported by directory buckets. You can only specifynull
to theversionId
query parameter in the request.
For more information about versioning, see PutBucketVersioning.
- Returns:
- Version ID used to reference a specific version of the object.
By default, the
GetObject
operation returns the current version of an object. To return a different version, use theversionId
subresource.-
If you include a
versionId
in your request header, you must have thes3:GetObjectVersion
permission to access a specific version of an object. Thes3:GetObject
permission is not required in this scenario. -
If you request the current version of an object without a specific
versionId
in the request header, only thes3:GetObject
permission is required. Thes3:GetObjectVersion
permission is not required in this scenario. -
Directory buckets - S3 Versioning isn't enabled and supported for directory buckets. For this API operation, only the
null
value of the version ID is supported by directory buckets. You can only specifynull
to theversionId
query parameter in the request.
For more information about versioning, see PutBucketVersioning.
-
-
-
sseCustomerAlgorithm
public final String sseCustomerAlgorithm()
Specifies the algorithm to use when decrypting the object (for example,
AES256
).If you encrypt an object by using server-side encryption with customer-provided encryption keys (SSE-C) when you store the object in Amazon S3, then when you GET the object, you must use the following headers:
-
x-amz-server-side-encryption-customer-algorithm
-
x-amz-server-side-encryption-customer-key
-
x-amz-server-side-encryption-customer-key-MD5
For more information about SSE-C, see Server-Side Encryption (Using Customer-Provided Encryption Keys) in the Amazon S3 User Guide.
This functionality is not supported for directory buckets.
- Returns:
- Specifies the algorithm to use when decrypting the object (for example,
AES256
).If you encrypt an object by using server-side encryption with customer-provided encryption keys (SSE-C) when you store the object in Amazon S3, then when you GET the object, you must use the following headers:
-
x-amz-server-side-encryption-customer-algorithm
-
x-amz-server-side-encryption-customer-key
-
x-amz-server-side-encryption-customer-key-MD5
For more information about SSE-C, see Server-Side Encryption (Using Customer-Provided Encryption Keys) in the Amazon S3 User Guide.
This functionality is not supported for directory buckets.
-
-
-
sseCustomerKey
public final String sseCustomerKey()
Specifies the customer-provided encryption key that you originally provided for Amazon S3 to encrypt the data before storing it. This value is used to decrypt the object when recovering it and must match the one used when storing the data. The key must be appropriate for use with the algorithm specified in the
x-amz-server-side-encryption-customer-algorithm
header.If you encrypt an object by using server-side encryption with customer-provided encryption keys (SSE-C) when you store the object in Amazon S3, then when you GET the object, you must use the following headers:
-
x-amz-server-side-encryption-customer-algorithm
-
x-amz-server-side-encryption-customer-key
-
x-amz-server-side-encryption-customer-key-MD5
For more information about SSE-C, see Server-Side Encryption (Using Customer-Provided Encryption Keys) in the Amazon S3 User Guide.
This functionality is not supported for directory buckets.
- Returns:
- Specifies the customer-provided encryption key that you originally provided for Amazon S3 to encrypt the
data before storing it. This value is used to decrypt the object when recovering it and must match the
one used when storing the data. The key must be appropriate for use with the algorithm specified in the
x-amz-server-side-encryption-customer-algorithm
header.If you encrypt an object by using server-side encryption with customer-provided encryption keys (SSE-C) when you store the object in Amazon S3, then when you GET the object, you must use the following headers:
-
x-amz-server-side-encryption-customer-algorithm
-
x-amz-server-side-encryption-customer-key
-
x-amz-server-side-encryption-customer-key-MD5
For more information about SSE-C, see Server-Side Encryption (Using Customer-Provided Encryption Keys) in the Amazon S3 User Guide.
This functionality is not supported for directory buckets.
-
-
-
sseCustomerKeyMD5
public final String sseCustomerKeyMD5()
Specifies the 128-bit MD5 digest of the customer-provided encryption key according to RFC 1321. Amazon S3 uses this header for a message integrity check to ensure that the encryption key was transmitted without error.
If you encrypt an object by using server-side encryption with customer-provided encryption keys (SSE-C) when you store the object in Amazon S3, then when you GET the object, you must use the following headers:
-
x-amz-server-side-encryption-customer-algorithm
-
x-amz-server-side-encryption-customer-key
-
x-amz-server-side-encryption-customer-key-MD5
For more information about SSE-C, see Server-Side Encryption (Using Customer-Provided Encryption Keys) in the Amazon S3 User Guide.
This functionality is not supported for directory buckets.
- Returns:
- Specifies the 128-bit MD5 digest of the customer-provided encryption key according to RFC 1321. Amazon S3
uses this header for a message integrity check to ensure that the encryption key was transmitted without
error.
If you encrypt an object by using server-side encryption with customer-provided encryption keys (SSE-C) when you store the object in Amazon S3, then when you GET the object, you must use the following headers:
-
x-amz-server-side-encryption-customer-algorithm
-
x-amz-server-side-encryption-customer-key
-
x-amz-server-side-encryption-customer-key-MD5
For more information about SSE-C, see Server-Side Encryption (Using Customer-Provided Encryption Keys) in the Amazon S3 User Guide.
This functionality is not supported for directory buckets.
-
-
-
requestPayer
public final RequestPayer requestPayer()
Returns the value of the RequestPayer property for this object.If the service returns an enum value that is not available in the current SDK version,
requestPayer
will returnRequestPayer.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available fromrequestPayerAsString()
.- Returns:
- The value of the RequestPayer property for this object.
- See Also:
RequestPayer
-
requestPayerAsString
public final String requestPayerAsString()
Returns the value of the RequestPayer property for this object.If the service returns an enum value that is not available in the current SDK version,
requestPayer
will returnRequestPayer.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available fromrequestPayerAsString()
.- Returns:
- The value of the RequestPayer property for this object.
- See Also:
RequestPayer
-
partNumber
public final Integer partNumber()
Part number of the object being read. This is a positive integer between 1 and 10,000. Effectively performs a 'ranged' GET request for the part specified. Useful for downloading just a part of an object.
- Returns:
- Part number of the object being read. This is a positive integer between 1 and 10,000. Effectively performs a 'ranged' GET request for the part specified. Useful for downloading just a part of an object.
-
expectedBucketOwner
public final String expectedBucketOwner()
The account ID of the expected bucket owner. If the account ID that you provide does not match the actual owner of the bucket, the request fails with the HTTP status code
403 Forbidden
(access denied).- Returns:
- The account ID of the expected bucket owner. If the account ID that you provide does not match the actual
owner of the bucket, the request fails with the HTTP status code
403 Forbidden
(access denied).
-
checksumMode
public final ChecksumMode checksumMode()
To retrieve the checksum, this mode must be enabled.
If the service returns an enum value that is not available in the current SDK version,
checksumMode
will returnChecksumMode.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available fromchecksumModeAsString()
.- Returns:
- To retrieve the checksum, this mode must be enabled.
- See Also:
ChecksumMode
-
checksumModeAsString
public final String checksumModeAsString()
To retrieve the checksum, this mode must be enabled.
If the service returns an enum value that is not available in the current SDK version,
checksumMode
will returnChecksumMode.UNKNOWN_TO_SDK_VERSION
. The raw value returned by the service is available fromchecksumModeAsString()
.- Returns:
- To retrieve the checksum, this mode must be enabled.
- See Also:
ChecksumMode
-
toBuilder
public GetObjectRequest.Builder toBuilder()
- Specified by:
toBuilder
in interfaceToCopyableBuilder<GetObjectRequest.Builder,GetObjectRequest>
- Specified by:
toBuilder
in classS3Request
-
builder
public static GetObjectRequest.Builder builder()
-
serializableBuilderClass
public static Class<? extends GetObjectRequest.Builder> serializableBuilderClass()
-
hashCode
public final int hashCode()
- Overrides:
hashCode
in classAwsRequest
-
equals
public final boolean equals(Object obj)
- Overrides:
equals
in classAwsRequest
-
equalsBySdkFields
public final boolean equalsBySdkFields(Object obj)
- Specified by:
equalsBySdkFields
in interfaceSdkPojo
-
toString
public final String toString()
Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be redacted from this string using a placeholder value.
-
getValueForField
public final <T> Optional<T> getValueForField(String fieldName, Class<T> clazz)
- Overrides:
getValueForField
in classSdkRequest
-
sdkFieldNameToField
public final Map<String,SdkField<?>> sdkFieldNameToField()
- Specified by:
sdkFieldNameToField
in interfaceSdkPojo
-
-