Java amazonS3.generatePresignedUrl - Как настроить https://s3.amazonaws.com/mycompany вместо https://mycompany.s3.amazonaws.com/com.mycompany

Мы используем предопределенные URL-адреса s3 для предоставления веб-доступа к изображениям, хранящимся в s3.

Java-код, который мы используем для генерации предварительно назначенных URL-адресов, похож на ниже

String accessKey = ...;
String secretKey = ...;
String region = ...;
com.amazonaws.HttpMethod awsHttpMethod = ...;
String bucketName = ...;
String objectKey = ...;
Date expirationDate = ...;

BasicAWSCredentials creds = new BasicAWSCredentials(accessKey, secretKey);
AmazonS3 s3Client = AmazonS3ClientBuilder.standard().withCredentials(new AWSStaticCredentialsProvider(creds)).withRegion(region).build();
GeneratePresignedUrlRequest generatePresignedUrlRequest = new GeneratePresignedUrlRequest(bucketName, objectKey);
generatePresignedUrlRequest.setMethod(awsHttpMethod);
generatePresignedUrlRequest.setExpiration(expirationDate);
URL url = s3Client.generatePresignedUrl(generatePresignedUrlRequest);

URL-адрес, сгенерированный кодом, похож на

https://com.mycompany.personalpictures.s3.amazonaws.com/picture123.png?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Date=20170623T150540Z&X-Amz-SignedHeaders=host&X-Amz-Expires=59&X-Amz-Credential=AKIAIVLB4ANK6B45G3IA%2F20170623%2Fus-east-1%2Fs3%2Faws4_request&X-Amz-Signature=d25d407ee8efa76f339388ec93579a19be8eaead9663d6d378cf2ec6d9d9cac2

Однако, поскольку наш стандарт именования сегментов содержит точки, обращение к указанному выше URL приводит к SSL: no alternative certificate subject name matches target host name 'com.mycompany.personalpictures.s3.amazonaws.com' ошибка

В этом посте я прочитал, что основной причиной являются точки в имени сегмента и что использование https://s3.amazonaws.com/com.mycompany.personalpictures/picture123.png должно обойти эту проблему.

Как я могу создать предварительно назначенные URL-адреса, используя формат URL-адреса https://s3.amazonaws.com/mybucket/myfile?

1 ответ

Решение

Догадаться...

Необходимо использовать.enablePathStyleAccess() при создании клиента s3. С этим строка кода сейчас

AmazonS3 s3Client = AmazonS3ClientBuilder.standard().withCredentials(new AWSStaticCredentialsProvider(creds)).withRegion(region).enablePathStyleAccess().build();
Другие вопросы по тегам