2017-09-18 1 views
0

Je reçois une méthode 405 non autorisée en essayant de récupérer des métadonnées d'anciennes versions d'un objet S3 à l'aide d'une fonction Lambda Java.S3 obtenir des métadonnées d'objets de version antérieure

AmazonS3 amazonS3 = getAmazonS3(); 
GetObjectRequest getObjectRequest = new GetObjectRequest(bucket, templateKey, versionId); 
ObjectMetadata objectMetadata = amazonS3.getObject(getObjectRequest).getObjectMetadata(); // Exception thrown at this line 

public AmazonS3 getAmazonS3() { 
    String region = PropertyManager.getValue(PropertyKey.AWS_REGION.getKey(stage)); 
    return AmazonS3ClientBuilder.standard().withRegion(region) 
       .withCredentials(new EnvironmentVariableCredentialsProvider()).build(); 
    } 

trace de pile dans Lambda:

The specified method is not allowed against this resource. (Service: Amazon S3; Status Code: 405; Error Code: MethodNotAllowed; Request ID: 1D12DDA5F0493282): com.amazonaws.services.s3.model.AmazonS3Exception 
com.amazonaws.services.s3.model.AmazonS3Exception: The specified method is not allowed against this resource. (Service: Amazon S3; Status Code: 405; Error Code: MethodNotAllowed; Request ID: 1D12DDA5F0493282), S3 Extended Request ID: jTNnAl8ifgsUlPMV0GEHAEVBtWwjTprEJy45C9BMJ5kTk/Qn8Pne8/ZM/tH27ZoeUtHrd1NeuyQ= 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.handleErrorResponse(AmazonHttpClient.java:1588) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.executeOneRequest(AmazonHttpClient.java:1258) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.executeHelper(AmazonHttpClient.java:1030) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.doExecute(AmazonHttpClient.java:742) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.executeWithTimer(AmazonHttpClient.java:716) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.execute(AmazonHttpClient.java:699) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutor.access$500(AmazonHttpClient.java:667) 
    at com.amazonaws.http.AmazonHttpClient$RequestExecutionBuilderImpl.execute(AmazonHttpClient.java:649) 
    at com.amazonaws.http.AmazonHttpClient.execute(AmazonHttpClient.java:513) 
    at com.amazonaws.services.s3.AmazonS3Client.invoke(AmazonS3Client.java:4187) 
    at com.amazonaws.services.s3.AmazonS3Client.invoke(AmazonS3Client.java:4134) 
    at com.amazonaws.services.s3.AmazonS3Client.getObject(AmazonS3Client.java:1385) 
    at com.ghx.templateengine.template.GetTemplateVersions.handleRequest(GetTemplateVersions.java:66) 
+0

Obtenez-vous la même exception lorsque vous essayez de récupérer l'objet lui-même et non ses métadonnées? –

+0

Je suis capable de récupérer l'objet lorsque je ne spécifie pas l'ID version. Si je spécifie alors je reçois une erreur similaire. –

Répondre

0

Quelques-unes des anciennes versions de l'objet S3 avait marqueur de suppression. La prise en charge d'AWS a indiqué que le fait d'essayer de diriger l'objet vers une version qui est un marqueur de suppression entraîne une erreur 405.