AWS services or capabilities described in AWS Documentation may vary by region/location. Click Getting Started with Amazon AWS to see specific differences applicable to the China (Beijing) Region.
The parameters to create a pre-signed URL to a bucket or object.
Namespace: Amazon.S3.Model
Assembly: AWSSDK.S3.dll
Version: 3.x.y.z
public class GetPreSignedUrlRequest : AmazonWebServiceRequest IAmazonWebServiceRequest
The GetPreSignedUrlRequest type exposes the following members
Name | Description | |
---|---|---|
![]() |
GetPreSignedUrlRequest() |
Name | Type | Description | |
---|---|---|---|
![]() |
BucketName | System.String |
The name of the bucket to create a pre-signed url to, or containing the object. |
![]() |
ContentType | System.String |
A standard MIME type describing the format of the object data. |
![]() |
Expires | System.Nullable<System.DateTime> |
The expiry date and time for the pre-signed url. |
![]() |
Headers | Amazon.S3.Model.HeadersCollection |
The collection of headers for the request. |
![]() |
Key | System.String |
The key to the object for which a pre-signed url should be created. |
![]() |
Metadata | Amazon.S3.Model.MetadataCollection |
The collection of meta data for the request. |
![]() |
Parameters | Amazon.S3.Model.ParameterCollection |
Custom parameters to include in the signed request, so that they are tamper-proof. |
![]() |
PartNumber | System.Nullable<System.Int32> |
The part number for the multipart upload for which a pre-signed url should be created. |
![]() |
Protocol | Amazon.S3.Protocol |
The requested protocol (http/https) for the pre-signed url. |
![]() |
RequestPayer | Amazon.S3.RequestPayer |
Confirms that the requester knows that she or he will be charged for the request. Bucket owners need not specify this parameter in their requests. |
![]() |
ResponseHeaderOverrides | Amazon.S3.Model.ResponseHeaderOverrides |
A set of response headers that should be returned with the pre-signed url creation response. |
![]() |
ServerSideEncryptionCustomerMethod | Amazon.S3.ServerSideEncryptionCustomerMethod |
The Server-side encryption algorithm to be used with the customer provided key. |
![]() |
ServerSideEncryptionKeyManagementServiceKeyId | System.String |
The id of the AWS Key Management Service key that Amazon S3 should use to encrypt and decrypt the object. If a key id is not specified, the default key will be used for encryption and decryption. |
![]() |
ServerSideEncryptionMethod | Amazon.S3.ServerSideEncryptionMethod |
Specifies the encryption used on the server to store the content. |
![]() |
UploadId | System.String |
The upload id for the multipart upload for which a pre-signed url should be created. |
![]() |
Verb | Amazon.S3.HttpVerb |
The verb for the pre-signed url. |
![]() |
VersionId | System.String |
Version id for the object that the pre-signed url will reference. If not set, the url will reference the latest version of the object. |
Name | Description | |
---|---|---|
![]() |
IsSetExpires() |
Checks if Expires property is set. |
The following examples show how to create various different pre-signed URLs.
The code sample shows a GetContents function. This will be referred to in subsequent samples to test out the generated URL.
public static async Task<string> GetContents(string path) { using var httpClient = new HttpClient(); return await httpClient.GetStringAsync(path); }
The first example creates a URL that will allow a third party to retrieve an object from S3 for a period of 5 minutes.
// Create a client AmazonS3Client client = new AmazonS3Client(); // Create a CopyObject request GetPreSignedUrlRequest request = new GetPreSignedUrlRequest { BucketName = "amzn-s3-demo-bucket", Key = "Item1", Expires = DateTime.UtcNow.AddMinutes(5) }; // Get path for request string path = await client.GetPreSignedURLAsync(request); // Test by getting contents string contents = await GetContents(path);
The following example creates a URL that will allow a third party to retrieve an object from S3 for a period of 5 minutes, and it also sets the headers to specific content, caching and encoding values.
// Create a client AmazonS3Client client = new AmazonS3Client(); // Create a CopyObject request GetPreSignedUrlRequest request = new GetPreSignedUrlRequest { BucketName = "amzn-s3-demo-bucket", Key = "Item1", Expires = DateTime.UtcNow.AddMinutes(5) }; request.ResponseHeaderOverrides.ContentType = "text/xml+zip"; request.ResponseHeaderOverrides.ContentDisposition = "attachment; filename=dispName.pdf"; request.ResponseHeaderOverrides.CacheControl = "No-cache"; request.ResponseHeaderOverrides.ContentLanguage = "mi, en"; request.ResponseHeaderOverrides.Expires = "Thu, 01 Dec 1994 16:00:00 GMT"; request.ResponseHeaderOverrides.ContentEncoding = "x-gzip"; // Get path for request string path = await client.GetPreSignedURLAsync(request); // Test by getting contents string contents = await GetContents(path);
This example creates a URL that will allow a third party to list
all objects in a specific bucket. This URL will also expire in 5 minutes.
The URL response will be the XML response for a ListBucket request.
// Create a client AmazonS3Client client = new AmazonS3Client(); // Create a CopyObject request GetPreSignedUrlRequest request = new GetPreSignedUrlRequest { BucketName = "amzn-s3-demo-bucket", Expires = DateTime.UtcNow.AddMinutes(5) }; // Get path for request string path = await client.GetPreSignedURLAsync(request); // Retrieve objects string allObjects = await GetContents(path);
This example creates a URL that will allow a third party to list
all of the owner's buckets. This URL will also expire in 5 minutes.
The URL response will be the XML response for a ListBuckets request.
// Create a client AmazonS3Client client = new AmazonS3Client(); // Create a CopyObject request GetPreSignedUrlRequest request = new GetPreSignedUrlRequest { Expires = DateTime.UtcNow.AddMinutes(5) }; // Get path for request string path = await client.GetPreSignedURLAsync(request); // Retrieve buckets string allBuckets = await GetContents(path);
This final example creates a URL that allows a third party to put an object, then uses it to upload sample content. The URL is set to expire in 10 days.
// Create a client AmazonS3Client client = new AmazonS3Client(); // Create a CopyObject request GetPreSignedUrlRequest request = new GetPreSignedUrlRequest { BucketName = "amzn-s3-demo-bucket", Key = "Item1", Verb = HttpVerb.PUT, Expires = DateTime.UtcNow.AddDays(10) }; // Get path for request string path = await client.GetPreSignedURLAsync(request); // Prepare data byte[] data = UTF8Encoding.UTF8.GetBytes("Sample text."); using var httpClient = new HttpClient(); using var httpRequest = new HttpRequestMessage(HttpMethod.Put, path) { Content = new ByteArrayContent(data) }; using var httpResponse = await httpClient.SendAsync(httpRequest);
.NET:
Supported in: 8.0 and newer, Core 3.1
.NET Standard:
Supported in: 2.0
.NET Framework:
Supported in: 4.7.2 and newer