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 interfaceGetObjectRequest.Builder
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description Stringbucket()The bucket name containing the object.static GetObjectRequest.Builderbuilder()ChecksumModechecksumMode()To retrieve the checksum, this mode must be enabled.StringchecksumModeAsString()To retrieve the checksum, this mode must be enabled.booleanequals(Object obj)booleanequalsBySdkFields(Object obj)StringexpectedBucketOwner()The account ID of the expected bucket owner.<T> Optional<T>getValueForField(String fieldName, Class<T> clazz)inthashCode()StringifMatch()Return the object only if its entity tag (ETag) is the same as the one specified in this header; otherwise, return a412 Precondition Failederror.InstantifModifiedSince()Return the object only if it has been modified since the specified time; otherwise, return a304 Not Modifiederror.StringifNoneMatch()Return the object only if its entity tag (ETag) is different from the one specified in this header; otherwise, return a304 Not Modifiederror.InstantifUnmodifiedSince()Return the object only if it has not been modified since the specified time; otherwise, return a412 Precondition Failederror.Stringkey()Key of the object to get.IntegerpartNumber()Part number of the object being read.Stringrange()Downloads the specified byte range of an object.RequestPayerrequestPayer()Returns the value of the RequestPayer property for this object.StringrequestPayerAsString()Returns the value of the RequestPayer property for this object.StringresponseCacheControl()Sets theCache-Controlheader of the response.StringresponseContentDisposition()Sets theContent-Dispositionheader of the response.StringresponseContentEncoding()Sets theContent-Encodingheader of the response.StringresponseContentLanguage()Sets theContent-Languageheader of the response.StringresponseContentType()Sets theContent-Typeheader of the response.InstantresponseExpires()Sets theExpiresheader of the response.Map<String,SdkField<?>>sdkFieldNameToField()List<SdkField<?>>sdkFields()static Class<? extends GetObjectRequest.Builder>serializableBuilderClass()StringsseCustomerAlgorithm()Specifies the algorithm to use when decrypting the object (for example,AES256).StringsseCustomerKey()Specifies the customer-provided encryption key that you originally provided for Amazon S3 to encrypt the data before storing it.StringsseCustomerKeyMD5()Specifies the 128-bit MD5 digest of the customer-provided encryption key according to RFC 1321.GetObjectRequest.BuildertoBuilder()StringtoString()Returns a string representation of this object.StringversionId()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 Failederror.If both of the
If-MatchandIf-Unmodified-Sinceheaders are present in the request as follows:If-Matchcondition evaluates totrue, and;If-Unmodified-Sincecondition evaluates tofalse; then, S3 returns200 OKand 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 Failederror.If both of the
If-MatchandIf-Unmodified-Sinceheaders are present in the request as follows:If-Matchcondition evaluates totrue, and;If-Unmodified-Sincecondition evaluates tofalse; then, S3 returns200 OKand 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 Modifiederror.If both of the
If-None-MatchandIf-Modified-Sinceheaders are present in the request as follows:If-None-Matchcondition evaluates tofalse, and;If-Modified-Sincecondition evaluates totrue; then, S3 returns304 Not Modifiedstatus 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 Modifiederror.If both of the
If-None-MatchandIf-Modified-Sinceheaders are present in the request as follows:If-None-Matchcondition evaluates tofalse, and;If-Modified-Sincecondition evaluates totrue; then, S3 returns304 Not Modifiedstatus 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 Modifiederror.If both of the
If-None-MatchandIf-Modified-Sinceheaders are present in the request as follows:If-None-Matchcondition evaluates tofalse, and;If-Modified-Sincecondition evaluates totrue; then, S3 returns304 Not ModifiedHTTP 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 Modifiederror.If both of the
If-None-MatchandIf-Modified-Sinceheaders are present in the request as follows:If-None-Matchcondition evaluates tofalse, and;If-Modified-Sincecondition evaluates totrue; then, S3 returns304 Not ModifiedHTTP 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 Failederror.If both of the
If-MatchandIf-Unmodified-Sinceheaders are present in the request as follows:If-Matchcondition evaluates totrue, and;If-Unmodified-Sincecondition evaluates tofalse; then, S3 returns200 OKand 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 Failederror.If both of the
If-MatchandIf-Unmodified-Sinceheaders are present in the request as follows:If-Matchcondition evaluates totrue, and;If-Unmodified-Sincecondition evaluates tofalse; then, S3 returns200 OKand 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
GETrequest.- 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
GETrequest.
-
responseCacheControl
public final String responseCacheControl()
Sets the
Cache-Controlheader of the response.- Returns:
- Sets the
Cache-Controlheader of the response.
-
responseContentDisposition
public final String responseContentDisposition()
Sets the
Content-Dispositionheader of the response.- Returns:
- Sets the
Content-Dispositionheader of the response.
-
responseContentEncoding
public final String responseContentEncoding()
Sets the
Content-Encodingheader of the response.- Returns:
- Sets the
Content-Encodingheader of the response.
-
responseContentLanguage
public final String responseContentLanguage()
Sets the
Content-Languageheader of the response.- Returns:
- Sets the
Content-Languageheader of the response.
-
responseContentType
public final String responseContentType()
Sets the
Content-Typeheader of the response.- Returns:
- Sets the
Content-Typeheader of the response.
-
responseExpires
public final Instant responseExpires()
Sets the
Expiresheader of the response.- Returns:
- Sets the
Expiresheader of the response.
-
versionId
public final String versionId()
Version ID used to reference a specific version of the object.
By default, the
GetObjectoperation returns the current version of an object. To return a different version, use theversionIdsubresource.-
If you include a
versionIdin your request header, you must have thes3:GetObjectVersionpermission to access a specific version of an object. Thes3:GetObjectpermission is not required in this scenario. -
If you request the current version of an object without a specific
versionIdin the request header, only thes3:GetObjectpermission is required. Thes3:GetObjectVersionpermission is not required in this scenario. -
Directory buckets - S3 Versioning isn't enabled and supported for directory buckets. For this API operation, only the
nullvalue of the version ID is supported by directory buckets. You can only specifynullto theversionIdquery 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
GetObjectoperation returns the current version of an object. To return a different version, use theversionIdsubresource.-
If you include a
versionIdin your request header, you must have thes3:GetObjectVersionpermission to access a specific version of an object. Thes3:GetObjectpermission is not required in this scenario. -
If you request the current version of an object without a specific
versionIdin the request header, only thes3:GetObjectpermission is required. Thes3:GetObjectVersionpermission is not required in this scenario. -
Directory buckets - S3 Versioning isn't enabled and supported for directory buckets. For this API operation, only the
nullvalue of the version ID is supported by directory buckets. You can only specifynullto theversionIdquery 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-algorithmheader.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-algorithmheader.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,
requestPayerwill 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,
requestPayerwill 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,
checksumModewill 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,
checksumModewill 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:
toBuilderin interfaceToCopyableBuilder<GetObjectRequest.Builder,GetObjectRequest>- Specified by:
toBuilderin classS3Request
-
builder
public static GetObjectRequest.Builder builder()
-
serializableBuilderClass
public static Class<? extends GetObjectRequest.Builder> serializableBuilderClass()
-
hashCode
public final int hashCode()
- Overrides:
hashCodein classAwsRequest
-
equals
public final boolean equals(Object obj)
- Overrides:
equalsin classAwsRequest
-
equalsBySdkFields
public final boolean equalsBySdkFields(Object obj)
- Specified by:
equalsBySdkFieldsin 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:
getValueForFieldin classSdkRequest
-
sdkFieldNameToField
public final Map<String,SdkField<?>> sdkFieldNameToField()
- Specified by:
sdkFieldNameToFieldin interfaceSdkPojo
-
-