Commit f7196ca48cc0c177852a068a296066456ee6ad75
1 parent
6fcf15c1
对接文件系统
Showing
3 changed files
with
45 additions
and
32 deletions
Bsth-admin/src/main/java/com/ruoyi/config/MinioConfig.java
| 1 | package com.ruoyi.config; | 1 | package com.ruoyi.config; |
| 2 | 2 | ||
| 3 | +import io.minio.*; | ||
| 3 | import io.minio.errors.*; | 4 | import io.minio.errors.*; |
| 5 | +import io.minio.http.Method; | ||
| 4 | import org.springframework.beans.factory.InitializingBean; | 6 | import org.springframework.beans.factory.InitializingBean; |
| 5 | import org.springframework.context.annotation.Bean; | 7 | import org.springframework.context.annotation.Bean; |
| 6 | import org.springframework.stereotype.Component; | 8 | import org.springframework.stereotype.Component; |
| 7 | import org.springframework.beans.factory.annotation.Value; | 9 | import org.springframework.beans.factory.annotation.Value; |
| 8 | -import io.minio.MinioClient; | ||
| 9 | import org.springframework.web.multipart.MultipartFile; | 10 | import org.springframework.web.multipart.MultipartFile; |
| 10 | import org.springframework.web.util.UriUtils; | 11 | import org.springframework.web.util.UriUtils; |
| 11 | 12 | ||
| @@ -15,8 +16,6 @@ import java.nio.charset.StandardCharsets; | @@ -15,8 +16,6 @@ import java.nio.charset.StandardCharsets; | ||
| 15 | import java.security.InvalidKeyException; | 16 | import java.security.InvalidKeyException; |
| 16 | import java.security.NoSuchAlgorithmException; | 17 | import java.security.NoSuchAlgorithmException; |
| 17 | 18 | ||
| 18 | -import io.minio.PutObjectArgs; | ||
| 19 | - | ||
| 20 | import javax.annotation.Resource; | 19 | import javax.annotation.Resource; |
| 21 | 20 | ||
| 22 | @Component | 21 | @Component |
| @@ -81,17 +80,43 @@ public class MinioConfig implements InitializingBean { | @@ -81,17 +80,43 @@ public class MinioConfig implements InitializingBean { | ||
| 81 | */ | 80 | */ |
| 82 | public Boolean upload(InputStream inputStream, String fileName, String contentType) { | 81 | public Boolean upload(InputStream inputStream, String fileName, String contentType) { |
| 83 | // 修饰过的文件名 非源文件名 | 82 | // 修饰过的文件名 非源文件名 |
| 84 | - | 83 | +// |
| 84 | +// try { | ||
| 85 | +// PutObjectArgs objectArgs = PutObjectArgs.builder().bucket(bucket).object(fileName) | ||
| 86 | +// .stream(inputStream, inputStream.available(), -1).contentType(contentType).build(); | ||
| 87 | +// //文件名称相同会覆盖 | ||
| 88 | +// minioClient.putObject(objectArgs); | ||
| 89 | +// } catch (Exception e) { | ||
| 90 | +// e.printStackTrace(); | ||
| 91 | +// return false; | ||
| 92 | +// } | ||
| 85 | try { | 93 | try { |
| 86 | - PutObjectArgs objectArgs = PutObjectArgs.builder().bucket(bucket).object(fileName) | ||
| 87 | - .stream(inputStream, inputStream.available(), -1).contentType(contentType).build(); | ||
| 88 | - //文件名称相同会覆盖 | ||
| 89 | - minioClient.putObject(objectArgs); | ||
| 90 | - } catch (Exception e) { | ||
| 91 | - e.printStackTrace(); | ||
| 92 | - return false; | 94 | + ObjectWriteResponse response= minioClient.putObject(PutObjectArgs.builder() |
| 95 | + .bucket(bucket) // 替换为你实际的存储桶名称 | ||
| 96 | + .object(fileName) | ||
| 97 | + .stream(inputStream, inputStream.available(), -1) | ||
| 98 | + .contentType(contentType) | ||
| 99 | + .build()); | ||
| 100 | + return true; | ||
| 101 | + } catch (ErrorResponseException e) { | ||
| 102 | + throw new RuntimeException(e); | ||
| 103 | + } catch (InsufficientDataException e) { | ||
| 104 | + throw new RuntimeException(e); | ||
| 105 | + } catch (InternalException e) { | ||
| 106 | + throw new RuntimeException(e); | ||
| 107 | + } catch (InvalidKeyException e) { | ||
| 108 | + throw new RuntimeException(e); | ||
| 109 | + } catch (InvalidResponseException e) { | ||
| 110 | + throw new RuntimeException(e); | ||
| 111 | + } catch (IOException e) { | ||
| 112 | + throw new RuntimeException(e); | ||
| 113 | + } catch (NoSuchAlgorithmException e) { | ||
| 114 | + throw new RuntimeException(e); | ||
| 115 | + } catch (ServerException e) { | ||
| 116 | + throw new RuntimeException(e); | ||
| 117 | + } catch (XmlParserException e) { | ||
| 118 | + throw new RuntimeException(e); | ||
| 93 | } | 119 | } |
| 94 | - return true; | ||
| 95 | } | 120 | } |
| 96 | 121 | ||
| 97 | 122 |
Bsth-admin/src/main/java/com/ruoyi/service/impl/sign/in/resource/LinggangSignInResourceServiceImpl.java
| @@ -135,13 +135,13 @@ public class LinggangSignInResourceServiceImpl extends ServiceImpl<LinggangSignI | @@ -135,13 +135,13 @@ public class LinggangSignInResourceServiceImpl extends ServiceImpl<LinggangSignI | ||
| 135 | entities = entities.stream().map(en -> { | 135 | entities = entities.stream().map(en -> { |
| 136 | StringBuilder builder = new StringBuilder(); | 136 | StringBuilder builder = new StringBuilder(); |
| 137 | builder.append("sign"); | 137 | builder.append("sign"); |
| 138 | - builder.append(File.separator); | 138 | + builder.append("/"); |
| 139 | builder.append("images"); | 139 | builder.append("images"); |
| 140 | - builder.append(File.separator); | 140 | + builder.append("/"); |
| 141 | builder.append(en.getDevice()); | 141 | builder.append(en.getDevice()); |
| 142 | - builder.append(File.separator); | 142 | + builder.append("/"); |
| 143 | builder.append(en.getSignId()); | 143 | builder.append(en.getSignId()); |
| 144 | - builder.append(File.separator); | 144 | + builder.append("/"); |
| 145 | builder.append(UUID.randomUUID().toString().replace("-", "")); | 145 | builder.append(UUID.randomUUID().toString().replace("-", "")); |
| 146 | builder.append("."); | 146 | builder.append("."); |
| 147 | builder.append(en.getPicType()); | 147 | builder.append(en.getPicType()); |
Bsth-admin/src/main/java/com/ruoyi/utils/UploadUtil.java
| @@ -5,6 +5,7 @@ import com.ruoyi.common.core.domain.ResponseResult; | @@ -5,6 +5,7 @@ import com.ruoyi.common.core.domain.ResponseResult; | ||
| 5 | import com.ruoyi.common.utils.StringUtils; | 5 | import com.ruoyi.common.utils.StringUtils; |
| 6 | import com.ruoyi.common.utils.file.FileUploadUtils; | 6 | import com.ruoyi.common.utils.file.FileUploadUtils; |
| 7 | import com.ruoyi.config.BsthSystemConfig; | 7 | import com.ruoyi.config.BsthSystemConfig; |
| 8 | +import com.ruoyi.config.MinioConfig; | ||
| 8 | import lombok.extern.slf4j.Slf4j; | 9 | import lombok.extern.slf4j.Slf4j; |
| 9 | import org.apache.commons.io.FileUtils; | 10 | import org.apache.commons.io.FileUtils; |
| 10 | import org.apache.commons.io.IOUtils; | 11 | import org.apache.commons.io.IOUtils; |
| @@ -28,6 +29,8 @@ public class UploadUtil { | @@ -28,6 +29,8 @@ public class UploadUtil { | ||
| 28 | 29 | ||
| 29 | @Autowired | 30 | @Autowired |
| 30 | private BsthSystemConfig bsthSystemConfig; | 31 | private BsthSystemConfig bsthSystemConfig; |
| 32 | + @Autowired | ||
| 33 | + private MinioConfig minioConfig; | ||
| 31 | 34 | ||
| 32 | /** | 35 | /** |
| 33 | * 上传图片接口 | 36 | * 上传图片接口 |
| @@ -50,23 +53,8 @@ public class UploadUtil { | @@ -50,23 +53,8 @@ public class UploadUtil { | ||
| 50 | content = FileUploadUtils.choosePrictureContent(content); | 53 | content = FileUploadUtils.choosePrictureContent(content); |
| 51 | byte[] bytes = Base64.decode(content); | 54 | byte[] bytes = Base64.decode(content); |
| 52 | inputStream = new ByteArrayInputStream(bytes); | 55 | inputStream = new ByteArrayInputStream(bytes); |
| 53 | - bufferedImage = ImageIO.read(inputStream); | ||
| 54 | - if (bufferedImage.getWidth() < 0 || bufferedImage.getHeight() < 0) { | ||
| 55 | - return ResponseResult.error("请上传正确的图片"); | ||
| 56 | - } | ||
| 57 | - | ||
| 58 | - StringBuilder filePath = new StringBuilder(); | ||
| 59 | - filePath.append(bsthSystemConfig.getImageBasePath()); | ||
| 60 | - filePath.append(File.separator); | ||
| 61 | - filePath.append(path); | ||
| 62 | - | ||
| 63 | - File file = new File(filePath.toString()); | ||
| 64 | - if(!file.exists() || !file.isDirectory()){ | ||
| 65 | - FileUtils.forceMkdirParent(file); | ||
| 66 | - } | ||
| 67 | 56 | ||
| 68 | - ImageIO.write(bufferedImage, type, file); | ||
| 69 | - bufferedImage.flush(); | 57 | + minioConfig.upload(inputStream,path,"application/png"); |
| 70 | 58 | ||
| 71 | return ResponseResult.success(Boolean.TRUE); | 59 | return ResponseResult.success(Boolean.TRUE); |
| 72 | } catch (Exception e) { | 60 | } catch (Exception e) { |