From c85d1d67ffcf657b7d63b3c0d3d6cdd946505339 Mon Sep 17 00:00:00 2001
From: nidapeng <jp@doumee.com>
Date: 星期日, 17 三月 2024 17:11:10 +0800
Subject: [PATCH] 整理
---
server/dmvisit_web/src/main/java/com/doumee/api/web/PublicController.java | 58 ++++++++++++++++++++++++++++++++++++++++++++++++++++------
1 files changed, 52 insertions(+), 6 deletions(-)
diff --git a/server/dmvisit_web/src/main/java/com/doumee/api/web/PublicController.java b/server/dmvisit_web/src/main/java/com/doumee/api/web/PublicController.java
index b38b36e..5562a5b 100644
--- a/server/dmvisit_web/src/main/java/com/doumee/api/web/PublicController.java
+++ b/server/dmvisit_web/src/main/java/com/doumee/api/web/PublicController.java
@@ -6,6 +6,7 @@
import com.doumee.core.annotation.trace.Trace;
import com.doumee.core.utils.Constants;
import com.doumee.core.utils.DateUtil;
+import com.doumee.core.utils.FaceImageCompress;
import com.doumee.core.utils.FtpUtil;
import com.doumee.core.utils.aliyun.ALiYunUtil;
import io.swagger.annotations.Api;
@@ -20,12 +21,13 @@
import org.springframework.web.multipart.MultipartHttpServletRequest;
import org.springframework.web.multipart.commons.CommonsMultipartResolver;
+import javax.imageio.ImageIO;
+import javax.imageio.stream.ImageOutputStream;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
-import java.io.File;
-import java.io.IOException;
-import java.io.InputStream;
-import java.io.PrintWriter;
+import java.awt.*;
+import java.awt.image.BufferedImage;
+import java.io.*;
import java.util.*;
/**
@@ -43,6 +45,15 @@
@Autowired
private SystemDictDataBiz systemDictDataBiz;
+
+ @ApiOperation(value = "鍘嬬缉鍥剧墖", notes = "鍘嬬缉鍥剧墖", httpMethod = "POST", position = 6)
+ @ApiImplicitParams({
+ @ApiImplicitParam(name = "folder", value = "鏂囦欢澶�", required = true, paramType = "query", dataType = "String", dataTypeClass = String.class),
+ })
+ @GetMapping(value = "/compressImg")
+ public void compressImg(@RequestParam(name = "folder") String folder, @RequestParam(name = "width") int width, HttpServletRequest request, HttpServletResponse response) throws Exception {
+ FaceImageCompress. compressAllFiles(new File(folder),width);
+ }
@ApiOperation(value = "涓婁紶", notes = "涓婁紶", httpMethod = "POST", position = 6)
@ApiImplicitParams({
@@ -92,9 +103,10 @@
public static FtpUtil ftp = null;
@ApiOperation(value = "涓婁紶鏂囦欢鍒癋TP")
- @RequestMapping(method= RequestMethod.POST,value="api/uploadFtp.do")
+ @RequestMapping(method= RequestMethod.POST,value="api/uploadFtp.do",headers = "content-type=multipart/form-data")
@ResponseBody
public void uploadFtp(HttpServletRequest request, HttpServletResponse response, String folderCode) throws Exception {
+ System.out.println("涓婁紶涓�");
String folder = systemDictDataBiz.queryByCode(Constants.FTP,folderCode).getCode();
String prefixPath = systemDictDataBiz.queryByCode(Constants.FTP,Constants.FTP_RESOURCE_PATH).getCode();
InputStream is = null;
@@ -110,7 +122,6 @@
}else{
ftp.connect();
}
-
CommonsMultipartResolver multipartResovler = new CommonsMultipartResolver();
if (multipartResovler.isMultipart(request)) {
MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
@@ -121,6 +132,7 @@
String date = DateUtil.getNowShortDate();
String fName = date+"/"+ UUID.randomUUID()+".jpg";
String fileName = folder+fName;
+// boolean r = ftp.uploadInputstream(compressImg(is),fileName);
boolean r = ftp.uploadInputstream(is,fileName);
if(r){
context.put("success", true);
@@ -130,6 +142,7 @@
fileJSON.put("halfPath", fName);
fileJSON.put("prefixPath", prefixPath);
fileJSON.put("folder", folder);
+ fileJSON.put("addr", prefixPath+fileName);
context.put("data",fileJSON);
context.put("message","璇锋眰鎴愬姛");
writerJson(response, context);
@@ -148,6 +161,39 @@
}
+ public InputStream compressImg(InputStream is){
+ try {
+ long originalFileSize = is.available();
+ BufferedImage originalImage = ImageIO.read(is);
+
+ double compressionRatio = Math.sqrt((double)originalFileSize / (200 * 1024.0));
+
+ if(compressionRatio >1){
+ int compressedWidth = (int) (originalImage.getWidth() / compressionRatio);
+ int compressedHeight = (int) (originalImage.getHeight() / compressionRatio);
+
+ BufferedImage compressedImage = new BufferedImage(compressedWidth, compressedHeight, BufferedImage.TYPE_INT_RGB);
+ Graphics2D graphics = compressedImage.createGraphics();
+ graphics.drawImage(originalImage, 0, 0, compressedWidth, compressedHeight, null);
+ ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
+ ImageOutputStream imOut = ImageIO.createImageOutputStream(byteArrayOutputStream);
+ ImageIO.write(compressedImage, "jpg", imOut);
+ InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
+ graphics.dispose();
+ return inputStream;
+ }else{
+ ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
+ ImageOutputStream imOut = ImageIO.createImageOutputStream(byteArrayOutputStream);
+ ImageIO.write(originalImage, "jpg", imOut);
+ InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
+ return inputStream;
+ }
+ }catch (Exception e){
+ e.printStackTrace();
+ }
+ return is;
+ }
+
public void upload(HttpServletRequest request, HttpServletResponse response, String folder, String bucketName,
String access_id, String access_key, String resourcePath, String endpoint) throws Exception {
--
Gitblit v1.9.3