java - 使用Java2 aws sdk时如何配置Region?

标签 java amazon-web-services scala amazon-s3 aws-sdk-java-2.0

我编写了以下 Controller 来生成预签名 S3 上传链接。

case class S3Controller(private val s3Config: S3Config, private val awsConfig: AwsConfig) {
  val URL_TIMEOUT_IN_MILLIS: Long = 60 * 5 * 1000

  def getPreSignedURLForUpload(keyName: String): String = {
    val preSigner: S3Presigner = DefaultS3Presigner.builder()
      .serviceConfiguration(s3Config.s3Configuration)
      .credentialsProvider(awsConfig.awsCredentialsProvider).build()

    val objectRequest: PutObjectRequest = PutObjectRequest.builder()
      .bucket(s3Config.bucketName)
      .key(keyName)
      .contentType("text/plain")
      .build()

    val preSignRequest: PutObjectPresignRequest = PutObjectPresignRequest.builder()
      .signatureDuration(Duration.ofMinutes(10))
      .putObjectRequest(objectRequest)
      .build()

    val preSignedRequest: PresignedPutObjectRequest = preSigner.presignPutObject(preSignRequest)


    val myURL: String = preSignedRequest.url().toString

    myURL
  }
}

我使用的配置对象

case class S3Config (
                      bucketName: String,
                      s3Configuration: S3Configuration
                    )
case class AwsConfig (
                       awsCredentialsProvider: AwsCredentialsProvider
                     )

我尝试用下面的代码来测试它

  test("S3 Controller"){
    val s3Configuration: S3Configuration = S3Configuration.builder()
      .pathStyleAccessEnabled(true).build()

    val s3Config: S3Config = S3Config(
      bucketName = "ccc",
      s3Configuration = s3Configuration
    )

    val awsCredentials: AwsCredentials = AwsBasicCredentials.create("aaa", "bbb")
    val awsCredentialsProvider: AwsCredentialsProvider = AwsCredentialsProviderChain.of(StaticCredentialsProvider.create(awsCredentials))
    
    val awsConfig: AwsConfig = AwsConfig(awsCredentialsProvider = awsCredentialsProvider)

    val s3Controller: S3Controller = S3Controller(s3Config, awsConfig)

    s3Controller.getPreSignedURLForUpload("ab")
  }

此测试失败并显示消息

Unable to load region from any of the providers in the chain software.amazon.awssdk.regions.providers.DefaultAwsRegionProviderChain@4e5ed836: [software.amazon.awssdk.regions.providers.SystemSettingsRegionProvider@5f8edcc5: Unable to load region from system settings. Region must be specified either via environment variable (AWS_REGION) or  system property (aws.region)., software.amazon.awssdk.regions.providers.AwsProfileRegionProvider@60015ef5: No region provided in profile: default, software.amazon.awssdk.regions.providers.InstanceProfileRegionProvider@2ab4bc72: Unable to contact EC2 metadata service.]
software.amazon.awssdk.core.exception.SdkClientException: Unable to load region from any of the providers in the chain software.amazon.awssdk.regions.providers.DefaultAwsRegionProviderChain@4e5ed836: [software.amazon.awssdk.regions.providers.SystemSettingsRegionProvider@5f8edcc5: Unable to load region from system settings. Region must be specified either via environment variable (AWS_REGION) or  system property (aws.region)., software.amazon.awssdk.regions.providers.AwsProfileRegionProvider@60015ef5: No region provided in profile: default, software.amazon.awssdk.regions.providers.InstanceProfileRegionProvider@2ab4bc72: Unable to contact EC2 metadata service.]

我知道这是因为我没有在任何地方配置区域。
所有配置 Region 的方法都是通过环境变量或配置文件。

有没有办法以编程方式配置区域?

最佳答案

当您使用 builder() 声明服务对象时,您设置了一个区域:

Region region = Region.US_EAST_1;
S3Presigner presigner = S3Presigner.builder()
                .region(region)
                .build();

所有 Java V2 代码示例都显示了这种设置区域的方式:

https://github.com/awsdocs/aws-doc-sdk-examples/tree/master/javav2/example_code/s3/src/main/java/com/example/s3

关于java - 使用Java2 aws sdk时如何配置Region?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68108281/

相关文章:

java - 在 MVP 中,onClick 是 View 还是 Presenter 的责任?

java - 有没有更简单的方法将 mysql 驱动程序加载到类路径?

amazon-web-services - 如何在 aws lambda 机器上安装 ffmpeg?

amazon-web-services - API 网关 - 请求过多异常 (429)

node.js - Scala.js - 从 SBT 运行传递命令行参数

java - 从事件监听器开始

java - 将 txt 文件添加到可运行的 JAR 文件

amazon-web-services - CodeBuild 找不到目标 Internet 网关的 0.0.0.0/0 目的地

scala - 尽管有 Spark 过滤器,Hive 分区表仍会读取所有分区

json - ( Play 2.5) Option 的类型别名如何定义json 格式?