From 2b4cc24d344ccbcb5732971d1e92dfd0ad7d7ac7 Mon Sep 17 00:00:00 2001 From: minsu20 Date: Thu, 30 Nov 2023 02:13:32 +0900 Subject: [PATCH] =?UTF-8?q?hotfix:=20=EB=A7=88=EC=9D=B4=ED=8E=98=EC=9D=B4?= =?UTF-8?q?=EC=A7=80=20=EC=98=A4=EB=A5=98=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../domain/mypage/application/service/ProfileUseCase.java | 7 +++++-- .../java/com/moing/backend/global/config/s3/S3Service.java | 6 ++++-- 2 files changed, 9 insertions(+), 4 deletions(-) diff --git a/src/main/java/com/moing/backend/domain/mypage/application/service/ProfileUseCase.java b/src/main/java/com/moing/backend/domain/mypage/application/service/ProfileUseCase.java index fc7c88ca..979f060a 100644 --- a/src/main/java/com/moing/backend/domain/mypage/application/service/ProfileUseCase.java +++ b/src/main/java/com/moing/backend/domain/mypage/application/service/ProfileUseCase.java @@ -9,6 +9,7 @@ import org.springframework.stereotype.Service; import javax.transaction.Transactional; +import java.util.concurrent.CompletableFuture; @Service @RequiredArgsConstructor @@ -41,8 +42,10 @@ private String getUpdatedValue(String newValue, String currentValue) { } private void deletePreviousImage(UpdateProfileRequest updateProfileRequest, Member member) { - if (updateProfileRequest.getProfileImage() != null) { - s3Service.deleteImage(member.getProfileImage()); + if (updateProfileRequest.getProfileImage() != null && member.getProfileImage() != null) { + CompletableFuture.runAsync(() -> { + s3Service.deleteImage(member.getProfileImage()); + }); } } diff --git a/src/main/java/com/moing/backend/global/config/s3/S3Service.java b/src/main/java/com/moing/backend/global/config/s3/S3Service.java index 253a0de9..5f39dfdc 100644 --- a/src/main/java/com/moing/backend/global/config/s3/S3Service.java +++ b/src/main/java/com/moing/backend/global/config/s3/S3Service.java @@ -42,10 +42,12 @@ public void deleteImage(String fileUrl) { String splitStr = ".com/"; String fileName = fileUrl.substring(fileUrl.lastIndexOf(splitStr) + splitStr.length()); - amazonS3.deleteObject(new DeleteObjectRequest(bucket, fileName)); + if (amazonS3.doesObjectExist(bucket, fileName)) { + amazonS3.deleteObject(new DeleteObjectRequest(bucket, fileName)); + } } - private String createFileName(String fileExtension) { + private String createFileName(String fileExtension) { return UUID.randomUUID() + "." + fileExtension; }