2

我正在尝试通过 Java 库以编程方式访问 Amazon S3 存储桶。(从第三方应用程序进行基本的云管理)。作为第一步,我尝试打印存储桶是否存在(第 3 行)

AWSCredentials credentials=new BasicAWSCredentials("my-Access- Key","My- Secret-Key");
AmazonS3 s3client = AmazonS3ClientBuilder.standard().withCredentials(new AWSStaticCredentialsProvider(credentials)).withRegion(Regions.AP_EAST_1).build();
String bucketExists=String.valueOf(s3client.doesBucketExistV2("newBucketName"));

当我运行这行代码时,我收到一个异常说

com.amazonaws.services.s3.model.AmazonS3Exception: The AWS Access Key Id you provided does not exist in our records. (Service: Amazon S3; Status Code: 403; Error Code: InvalidAccessKeyId; Request ID:RequestId...)

由于以下原因,我不想在 .aws 文件夹中维护凭据文件:

我正在尝试根据来自安全 LDAP 系统的登录用户来改变访问凭据,因此只有在使用硬编码凭据对其进行测试时才能确认其可行性。

我已检查该问题不是以下问题之一

  • 我在 AWS 控制台中创建了一个具有有效访问 ID 和密钥的 IAM 用户,并允许该用户进行编程访问。
  • 我还为 IAM 用户应用了 AmazonS3FullAccess 策略
  • 密钥处于活动状态(已通过控制台检查)
  • 我已将 AWS SDK 的依赖项添加到 gradle(实现组:'com.amazonaws',名称:'aws-java-sdk-s3',版本:'1.12.15')

请让我知道问题可能是什么。如果是业余问题,我深表歉意。

4

2 回答 2

1

如问题注释中所示,您的代码看起来不错,应该可以正常工作。

问题的最可能原因是 AWS 正在从其他地方获取其他凭证。请尝试删除其他凭据,例如存储在主目录中的凭据,以确保 SDK 在联系 S3 时使用正确的凭据。

此外,请根据您的 S3 存储桶验证您是否提供了正确的区域。

于 2021-07-12T16:11:59.643 回答
0

您正在使用较旧的 V1 API。V1 的服务客户端名称是AmazonS3。同样,V2 服务客户端名称是 S3Client。亚马逊强烈建议迁移到 V2:

AWS SDK for Java 2.x 是对 1.x 版代码库的重大重写。它建立在 Java 8+ 之上,并添加了几个经常请求的特性。其中包括对非阻塞 I/O 的支持以及在运行时插入不同 HTTP 实现的能力。

尝试按照这组基于 V2 的分步说明进行操作。

开始使用适用于 Java 2.x 的 AWS 开发工具包

使用 V2 时,您可以将您的凭据放入名为 credentials 的 .aws 文件夹中的文件中,如本文档中所述。完成本文档中的所有步骤后,您可以以编程方式访问 Amazon S3 存储桶。

于 2021-07-02T13:05:48.010 回答