From ac1b43ab53fc3e9dd61e87ea7431abc3fe8345a0 Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Mon, 19 Feb 2024 10:25:20 +0800 Subject: [PATCH] 文件上传服务器地址 --- src/main/java/cc/mrbird/febs/common/utils/FileUtil.java | 67 +++++++++++++++++++++++++++++++++ src/main/java/cc/mrbird/febs/mall/controller/CommonController.java | 30 +++++++++++++++ src/main/resources/application-dev.yml | 5 ++ src/main/resources/application-prod.yml | 5 ++ src/main/resources/application-test.yml | 5 ++ 5 files changed, 112 insertions(+), 0 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/common/utils/FileUtil.java b/src/main/java/cc/mrbird/febs/common/utils/FileUtil.java index 69a5d5d..2e3138d 100644 --- a/src/main/java/cc/mrbird/febs/common/utils/FileUtil.java +++ b/src/main/java/cc/mrbird/febs/common/utils/FileUtil.java @@ -1,16 +1,25 @@ package cc.mrbird.febs.common.utils; import cc.mrbird.febs.common.entity.FebsConstant; +import cn.hutool.core.lang.UUID; import com.google.common.base.Preconditions; import lombok.extern.slf4j.Slf4j; +import net.coobird.thumbnailator.Thumbnails; import org.apache.commons.lang3.ArrayUtils; import org.apache.commons.lang3.StringUtils; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.util.FileCopyUtils; +import org.springframework.web.multipart.MultipartFile; +import javax.imageio.ImageIO; import javax.servlet.http.HttpServletResponse; +import java.awt.image.BufferedImage; import java.io.*; import java.nio.file.Files; import java.nio.file.Paths; import java.util.Arrays; +import java.util.HashMap; +import java.util.Map; import java.util.zip.CRC32; import java.util.zip.CheckedOutputStream; import java.util.zip.ZipEntry; @@ -25,6 +34,64 @@ private static final int BUFFER = 1024 * 8; /** + * 文件上传服务器本地路径 + */ + public static Map<String,Object> fileUploadEsc(MultipartFile file,String resourceUrl,String resourcePath) throws IOException { + // 文件保存目录路径 + String savePath = resourcePath; + // 文件保存目录URL + String saveUrl = resourceUrl; + // 检查目录 + File uploadDir = new File(savePath); + if (!uploadDir.isDirectory()) { + uploadDir.mkdir(); + } + // 获得文件的后缀 + String fileName = file.getOriginalFilename(); + String fileExt = fileName.substring(fileName.lastIndexOf(".") + 1); + String newFileName = UUID.randomUUID().toString() + "." + fileExt; + if (isImage(file.getInputStream())) { + Thumbnails.of(file.getInputStream()) + // 图片大小(长宽)压缩比例 从0-1,1表示原图 + .scale(1f) + // 图片质量压缩比例 从0-1,越接近1质量越好 + .outputQuality(0.9f) + .toOutputStream(new FileOutputStream(savePath + newFileName)); + } else { + File uploadedFile = new File(savePath, newFileName); + uploadedFile.setReadable(true, false); + uploadedFile.setExecutable(true, false); + uploadedFile.setWritable(true, false); + try { + //存文件 + FileCopyUtils.copy(file.getBytes(), uploadedFile); + file.transferTo(uploadedFile); + } catch (IOException e) { + e.printStackTrace(); + } + } + + String visitPath = (saveUrl + newFileName); + Map<String,Object> map = new HashMap<String,Object>(); + Map<String,Object> map2 = new HashMap<String,Object>(); + map2.put("src",visitPath);//图片url + map2.put("title",newFileName);//图片名称,这个会显示在输入框里 + map.put("code",0);//0表示成功,1失败 + map.put("msg","上传成功");//提示消息 + map.put("data",map2); + return map; + } + public static boolean isImage(InputStream inputStream) { + BufferedImage read = null; + try { + read = ImageIO.read(inputStream); + } catch (IOException e) { + return false; + } + return read != null; + } + + /** * 压缩文件或目录 * * @param fromPath 待压缩文件或路径 diff --git a/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java b/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java index 87f7a27..e268eba 100644 --- a/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java +++ b/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java @@ -8,19 +8,30 @@ import cc.mrbird.febs.mall.dto.Base64UploadDto; import cc.mrbird.febs.mall.entity.DataDictionaryCustom; import cc.mrbird.febs.mall.service.ICommonService; +import cn.hutool.core.io.file.FileNameUtil; +import cn.hutool.core.lang.UUID; import cn.hutool.core.util.IdUtil; import cn.hutool.core.util.StrUtil; +import com.thoughtworks.xstream.core.BaseException; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiParam; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; +import net.coobird.thumbnailator.Thumbnails; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.util.FileCopyUtils; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; import sun.misc.BASE64Encoder; +import javax.imageio.ImageIO; +import java.awt.image.BufferedImage; +import java.io.File; +import java.io.FileOutputStream; import java.io.IOException; +import java.io.InputStream; import java.util.HashMap; import java.util.List; import java.util.Map; @@ -115,6 +126,25 @@ } /** + * 通用上传请求 + */ + // 文件保存目录路径 + @Value("${static.resource.url}") + private String resourceUrl; + // 文件保存目录URL + @Value("${static.resource.path}") + private String resourcePath; + + @ApiOperation(value = "文件上传服务器", notes = "文件上传服务器") + @GetMapping(value = "/fileUploadEsc") + public Map<String,Object> fileUploadEsc(MultipartFile file) throws IOException { + if (file == null) { + throw new FebsException("上传文件不能为空"); + } + return FileUtil.fileUploadEsc(file,resourceUrl,resourcePath); + } + + /** * 图片上传 * @return */ diff --git a/src/main/resources/application-dev.yml b/src/main/resources/application-dev.yml index 272cda5..3e21820 100644 --- a/src/main/resources/application-dev.yml +++ b/src/main/resources/application-dev.yml @@ -81,5 +81,10 @@ gaodeKey: 95ede7157929f5f6b6c758971be924b1 serviceName: yiyuanshucai +static: + resource: + url: http://file.blnka.cn/file/ + path: /mnt/sdc/webresource/file/ + system: job: false \ No newline at end of file diff --git a/src/main/resources/application-prod.yml b/src/main/resources/application-prod.yml index af5002d..a610917 100644 --- a/src/main/resources/application-prod.yml +++ b/src/main/resources/application-prod.yml @@ -73,5 +73,10 @@ gaodeKey: 95ede7157929f5f6b6c758971be924b1 serviceName: yiyuanshucai +static: + resource: + url: http://file.blnka.cn/file/ + path: /mnt/sdc/webresource/file/ + system: job: true \ No newline at end of file diff --git a/src/main/resources/application-test.yml b/src/main/resources/application-test.yml index 0b43a6e..5e0a660 100644 --- a/src/main/resources/application-test.yml +++ b/src/main/resources/application-test.yml @@ -82,5 +82,10 @@ gaodeKey: 95ede7157929f5f6b6c758971be924b1 serviceName: yiyuanshucai +static: + resource: + url: http://file.blnka.cn/file/ + path: /mnt/sdc/webresource/file/ + system: job: true \ No newline at end of file -- Gitblit v1.9.1