Jump to Content

New API Documentation - Developer Preview Available

We are excited to announce the developer preview of our new API documentation for AWS SDK for JavaScript v3. Please follow instructions on the landing page to leave us your feedback.

Class DeleteObjectsCommandProtected

This action enables you to delete multiple objects from a bucket using a single HTTP request. If you know the object keys that you want to delete, then this action provides a suitable alternative to sending individual delete requests, reducing per-request overhead.

The request contains a list of up to 1000 keys that you want to delete. In the XML, you provide the object key names, and optionally, version IDs if you want to delete a specific version of the object from a versioning-enabled bucket. For each key, Amazon S3 performs a delete action and returns the result of that delete, success, or failure, in the response. Note that if the object specified in the request is not found, Amazon S3 returns the result as deleted.

The action supports two modes for the response: verbose and quiet. By default, the action uses verbose mode in which the response includes the result of deletion of each key in your request. In quiet mode the response includes only keys where the delete action encountered an error. For a successful deletion, the action does not return any information about the delete in the response body.

When performing this action on an MFA Delete enabled bucket, that attempts to delete any versioned objects, you must include an MFA token. If you do not provide one, the entire request will fail, even if there are non-versioned objects you are trying to delete. If you provide an invalid token, whether there are versioned keys in the request or not, the entire Multi-Object Delete request will fail. For information about MFA Delete, see MFA Delete.

Finally, the Content-MD5 header is required for all Multi-Object Delete requests. Amazon S3 uses the header value to ensure that your request body has not been altered in transit.

The following operations are related to DeleteObjects:

Example

Use a bare-bones client and the command you need to make an API call.

import { S3Client, DeleteObjectsCommand } from "@aws-sdk/client-s3"; // ES Modules import
// const { S3Client, DeleteObjectsCommand } = require("@aws-sdk/client-s3"); // CommonJS import
const client = new S3Client(config);
const input = { // DeleteObjectsRequest
Bucket: "STRING_VALUE", // required
Delete: { // Delete
Objects: [ // ObjectIdentifierList // required
{ // ObjectIdentifier
Key: "STRING_VALUE", // required
VersionId: "STRING_VALUE",
},
],
Quiet: true || false,
},
MFA: "STRING_VALUE",
RequestPayer: "requester",
BypassGovernanceRetention: true || false,
ExpectedBucketOwner: "STRING_VALUE",
ChecksumAlgorithm: "CRC32" || "CRC32C" || "SHA1" || "SHA256",
};
const command = new DeleteObjectsCommand(input);
const response = await client.send(command);
// { // DeleteObjectsOutput
// Deleted: [ // DeletedObjects
// { // DeletedObject
// Key: "STRING_VALUE",
// VersionId: "STRING_VALUE",
// DeleteMarker: true || false,
// DeleteMarkerVersionId: "STRING_VALUE",
// },
// ],
// RequestCharged: "requester",
// Errors: [ // Errors
// { // Error
// Key: "STRING_VALUE",
// VersionId: "STRING_VALUE",
// Code: "STRING_VALUE",
// Message: "STRING_VALUE",
// },
// ],
// };

Param

DeleteObjectsCommandInput

Returns

DeleteObjectsCommandOutput

See

Throws

S3ServiceException

Base exception class for all service exceptions from S3 service.

Example

To delete multiple object versions from a versioned bucket

// The following example deletes objects from a bucket. The request specifies object versions. S3 deletes specific object versions and returns the key and versions of deleted objects in the response.
const input = {
"Bucket": "examplebucket",
"Delete": {
"Objects": [
{
"Key": "HappyFace.jpg",
"VersionId": "2LWg7lQLnY41.maGB5Z6SWW.dcq0vx7b"
},
{
"Key": "HappyFace.jpg",
"VersionId": "yoz3HB.ZhCS_tKVEmIOr7qYyyAaZSKVd"
}
],
"Quiet": false
}
};
const command = new DeleteObjectsCommand(input);
const response = await client.send(command);
/* response ==
{
"Deleted": [
{
"Key": "HappyFace.jpg",
"VersionId": "yoz3HB.ZhCS_tKVEmIOr7qYyyAaZSKVd"
},
{
"Key": "HappyFace.jpg",
"VersionId": "2LWg7lQLnY41.maGB5Z6SWW.dcq0vx7b"
}
]
}
*/
// example id: to-delete-multiple-object-versions-from-a-versioned-bucket-1483147087737

Example

To delete multiple objects from a versioned bucket

// The following example deletes objects from a bucket. The bucket is versioned, and the request does not specify the object version to delete. In this case, all versions remain in the bucket and S3 adds a delete marker.
const input = {
"Bucket": "examplebucket",
"Delete": {
"Objects": [
{
"Key": "objectkey1"
},
{
"Key": "objectkey2"
}
],
"Quiet": false
}
};
const command = new DeleteObjectsCommand(input);
const response = await client.send(command);
/* response ==
{
"Deleted": [
{
"DeleteMarker": "true",
"DeleteMarkerVersionId": "A._w1z6EFiCF5uhtQMDal9JDkID9tQ7F",
"Key": "objectkey1"
},
{
"DeleteMarker": "true",
"DeleteMarkerVersionId": "iOd_ORxhkKe_e8G8_oSGxt2PjsCZKlkt",
"Key": "objectkey2"
}
]
}
*/
// example id: to-delete-multiple-objects-from-a-versioned-bucket-1483146248805

Hierarchy

Constructors

Properties

middlewareStack: MiddlewareStack<DeleteObjectsCommandInput, DeleteObjectsCommandOutput>

Methods