From 2db1aa88e8ab53096a936163d686b90d8e056a99 Mon Sep 17 00:00:00 2001
From: rain <167982779@qq.com>
Date: Wed, 21 Aug 2024 23:18:33 +0800
Subject: [PATCH] 国土对接返回信息加密

---
 src/main/java/com/dji/sample/component/oss/service/impl/MinIOServiceImpl.java |   44 ++++++++++++++++++--------------------------
 1 files changed, 18 insertions(+), 26 deletions(-)

diff --git a/src/main/java/com/dji/sample/component/oss/service/impl/MinIOServiceImpl.java b/src/main/java/com/dji/sample/component/oss/service/impl/MinIOServiceImpl.java
index b162751..d54368e 100644
--- a/src/main/java/com/dji/sample/component/oss/service/impl/MinIOServiceImpl.java
+++ b/src/main/java/com/dji/sample/component/oss/service/impl/MinIOServiceImpl.java
@@ -1,5 +1,6 @@
 package com.dji.sample.component.oss.service.impl;
 
+import com.dji.sample.common.model.ResponseResult;
 import com.dji.sample.component.oss.model.OssConfiguration;
 import com.dji.sample.component.oss.model.enums.OssTypeEnum;
 import com.dji.sample.component.oss.service.IOssService;
@@ -9,7 +10,6 @@
 import io.minio.errors.*;
 import io.minio.http.Method;
 import lombok.extern.slf4j.Slf4j;
-import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
 import java.io.ByteArrayInputStream;
@@ -31,9 +31,6 @@
 
     private MinioClient client;
 
-    @Autowired
-    private OssConfiguration configuration;
-
     @Override
     public String getOssType() {
         return OssTypeEnum.MINIO.getType();
@@ -42,10 +39,10 @@
     @Override
     public CredentialsDTO getCredentials() {
         try {
-            AssumeRoleProvider provider = new AssumeRoleProvider(configuration.getEndpoint(), configuration.getAccessKey(),
-                    configuration.getSecretKey(), Math.toIntExact(configuration.getExpire()),
-                    null, configuration.getRegion(), null, null, null, null);
-            return new CredentialsDTO(provider.fetch(), configuration.getExpire());
+            AssumeRoleProvider provider = new AssumeRoleProvider(OssConfiguration.externalEndpoint, OssConfiguration.accessKey,
+                    OssConfiguration.secretKey, Math.toIntExact(OssConfiguration.expire),
+                    null, OssConfiguration.region, null, null, null, null);
+            return new CredentialsDTO(provider.fetch(), OssConfiguration.expire);
         } catch (NoSuchAlgorithmException e) {
             log.debug("Failed to obtain sts.");
             e.printStackTrace();
@@ -57,26 +54,22 @@
     public URL getObjectUrl(String bucket, String objectKey) {
         try {
             return new URL(
-                    this.createClient()
-                            .getPresignedObjectUrl(
+                    client.getPresignedObjectUrl(
                                     GetPresignedObjectUrlArgs.builder()
                                             .method(Method.GET)
                                             .bucket(bucket)
                                             .object(objectKey)
-                                            .expiry(Math.toIntExact(configuration.getExpire()))
+                                            .expiry(Math.toIntExact(OssConfiguration.expire))
                                             .build()));
         } catch (ErrorResponseException | InsufficientDataException | InternalException |
                 InvalidKeyException | InvalidResponseException | IOException |
                 NoSuchAlgorithmException | XmlParserException | ServerException e) {
-            log.error("The file does not exist on the OssConfiguration.");
-            e.printStackTrace();
+            throw new RuntimeException("OssConfiguration上不存在该文件.");
         }
-        return null;
     }
 
     @Override
     public Boolean deleteObject(String bucket, String objectKey) {
-        MinioClient client = this.createClient();
         try {
             client.removeObject(RemoveObjectArgs.builder().bucket(bucket).object(objectKey).build());
         } catch (MinioException | NoSuchAlgorithmException | IOException | InvalidKeyException e) {
@@ -90,7 +83,7 @@
     @Override
     public InputStream getObject(String bucket, String objectKey) {
         try {
-            GetObjectResponse object = this.createClient().getObject(GetObjectArgs.builder().bucket(bucket).object(objectKey).build());
+            GetObjectResponse object = client.getObject(GetObjectArgs.builder().bucket(bucket).object(objectKey).build());
             return new ByteArrayInputStream(object.readAllBytes());
         } catch (ErrorResponseException | InsufficientDataException | InternalException | InvalidKeyException | InvalidResponseException | IOException | NoSuchAlgorithmException | ServerException | XmlParserException e) {
             e.printStackTrace();
@@ -99,13 +92,12 @@
     }
 
     @Override
-    public void putObject(String bucket, String objectKey, InputStream input) {
+    public String putObject(String bucket, String objectKey, InputStream input) {
         try {
-            MinioClient client = this.createClient();
             client.statObject(StatObjectArgs.builder().bucket(bucket).object(objectKey).build());
-            throw new RuntimeException("The filename already exists.");
+            return "航线名重复";
         } catch (MinioException | InvalidKeyException | IOException | NoSuchAlgorithmException e) {
-            log.info("The file does not exist, start uploading.");
+            log.info("文件不存在,开始上传。");
             try {
                 ObjectWriteResponse response = client.putObject(
                         PutObjectArgs.builder().bucket(bucket).object(objectKey).stream(input, input.available(), 0).build());
@@ -115,17 +107,17 @@
                 ex.printStackTrace();
             }
         }
+        return null;
     }
 
-    private MinioClient createClient() {
+    public void createClient() {
         if (Objects.nonNull(this.client)) {
-            return this.client;
+            return;
         }
         this.client = MinioClient.builder()
-                .endpoint(configuration.getEndpoint())
-                .credentials(configuration.getAccessKey(), configuration.getSecretKey())
-                .region(configuration.getRegion())
+                .endpoint(OssConfiguration.endpoint)
+                .credentials(OssConfiguration.accessKey, OssConfiguration.secretKey)
+                .region(OssConfiguration.region)
                 .build();
-        return this.client;
     }
 }

--
Gitblit v1.9.3