DEV Community

Cover image for How to Upload Files to AWS S3 Using Java: A Step-by-Step Guide
Samarth Gambhir
Samarth Gambhir

Posted on

How to Upload Files to AWS S3 Using Java: A Step-by-Step Guide

Introduction

Amazon Simple Storage Service (S3) is a powerful and scalable object storage service providing a reliable and cost-effective solution to store and retrieve any amount of data from anywhere on the web. In this article, we will explore how to interact with AWS S3 to upload files using Java and Spring Boot.

Prerequisites

Before diving into the code, ensure you have the following:

  • An AWS Account: Sign up for an account on the AWS Website
  • Java Development Environment: Ensure you have Java installed on your machine along with a build tool like Maven or Gradle for dependency management.
  • Basic Knowledge of Java: Familiarity with Java syntax and programming concepts will be helpful.

Setting Up AWS SDK for Java

To interact with AWS S3 using Java, you'll need the AWS SDK for Java. Here's how to add it to your project:

For Maven: Add the following dependency to your pom.xml file:

<dependency>
    <groupId>com.amazonaws</groupId>
    <artifactId>aws-java-sdk-s3</artifactId>
    <version>1.x.x</version> <!-- Replace with the latest version -->
</dependency>
Enter fullscreen mode Exit fullscreen mode

For Gradle: Add the following line to your build.gradle file:

implementation 'com.amazonaws:aws-java-sdk-s3:1.x.x' // Replace with the latest version
Enter fullscreen mode Exit fullscreen mode

Configuring AWS Credentials

To securely interact with AWS S3, you'll need to store your AWS credentials. In this tutorial, we'll use the application.properties file to manage credentials.

First, add the following lines to your application.properties file:

aws.accessKeyId=your-access-key-id
aws.secretKey=your-secret-access-key
aws.region=your-region
Enter fullscreen mode Exit fullscreen mode

Next, in your Java application, you can load these properties and use them to configure the AWS S3 client:

import com.amazonaws.auth.AWSCredentials;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

import com.amazonaws.auth.AWSStaticCredentialsProvider;
import com.amazonaws.auth.BasicAWSCredentials;
import com.amazonaws.services.s3.AmazonS3;
import com.amazonaws.services.s3.AmazonS3ClientBuilder;

@Component
public class S3ClientConfig {

    @Value("${aws.accessKeyId}")
    private String accessKeyId;

    @Value("${aws.secretKey}")
    private String secretKey;

    @Value("${aws.region}")
    private String region;

    public AmazonS3 initializeS3() {
        AWSCredentials credentials = new BasicAWSCredentials(accessKeyId, secretKey);
        return AmazonS3ClientBuilder.standard()
                .withCredentials(new AWSStaticCredentialsProvider(credentials)).withRegion(region).build();
    }
}
Enter fullscreen mode Exit fullscreen mode

Uploading Files to S3

Here is a sample method that demonstrates how to upload a file to AWS S3 using the AmazonS3 client.

import com.amazonaws.services.s3.AmazonS3;
import com.amazonaws.services.s3.model.PutObjectRequest;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.io.File;

@Service
public class S3Service {

    private final AmazonS3 s3Client;

    @Autowired
    public S3Service(S3ClientConfig s3ClientConfig) {
        this.s3Client = s3ClientConfig.initializeS3();
    }

    public void uploadFile(String bucketName, String filePath) {
        File file = new File(filePath);
        if (file.exists()) {
            s3Client.putObject(new PutObjectRequest(bucketName, file.getName(), file));
            System.out.println("File uploaded successfully.");
        } else {
            System.out.println("File not found: " + filePath);
        }
    }
}

Enter fullscreen mode Exit fullscreen mode

uploadFile() Method Breakdown:

Parameters:

  • bucketName: The name of the S3 bucket to upload the file to.
  • filePath: The local path to the file being uploaded.

File Creation & Existence Check:

  • A File object is created from the provided filePath
  • The method checks if the file exists using file.exists() If the file doesn't exist, it logs an error message.

Uploading the File:

  • If the file exists, it's uploaded to the S3 bucket using the putObject() method.
  • Logs a success message if the upload completes successfully.

Conclusion

In this article, we covered the process of uploading files to AWS S3 using Java. We explored how to configure AWS credentials, set up the S3 client using Spring Boot, and wrote a simple method to upload files to your S3 bucket. With this foundation, you can now integrate S3 file uploads into your Java applications seamlessly.

Top comments (0)