From 58c4a118bad3d33a553915781c9711d7bf2f6ee2 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Thu, 11 Aug 2022 12:07:21 +0800
Subject: [PATCH] fix

---
 src/main/java/com/xcong/farmer/cms/configurations/P6spySqlFormatConfigure.java          |   21 ++++++++++
 src/main/java/com/xcong/farmer/cms/modules/system/controller/AdminCommonController.java |   45 ++++++++++++++++++----
 pom.xml                                                                                 |   13 ++++++
 src/main/resources/application.yml                                                      |    2 +
 src/main/resources/spy.properties                                                       |   13 ++++++
 5 files changed, 85 insertions(+), 9 deletions(-)

diff --git a/pom.xml b/pom.xml
index 5030755..a96d29e 100644
--- a/pom.xml
+++ b/pom.xml
@@ -279,6 +279,19 @@
             <artifactId>commons-text</artifactId>
             <version>1.9</version>
         </dependency>
+
+        <!-- 控制台 SQL日志打印插件 -->
+        <dependency>
+            <groupId>p6spy</groupId>
+            <artifactId>p6spy</artifactId>
+            <version>3.8.1</version>
+        </dependency>
+
+        <dependency>
+            <groupId>net.coobird</groupId>
+            <artifactId>thumbnailator</artifactId>
+            <version>0.4.8</version>
+        </dependency>
     </dependencies>
 
     <build>
diff --git a/src/main/java/com/xcong/farmer/cms/configurations/P6spySqlFormatConfigure.java b/src/main/java/com/xcong/farmer/cms/configurations/P6spySqlFormatConfigure.java
new file mode 100644
index 0000000..b969f94
--- /dev/null
+++ b/src/main/java/com/xcong/farmer/cms/configurations/P6spySqlFormatConfigure.java
@@ -0,0 +1,21 @@
+package com.xcong.farmer.cms.configurations;
+
+import cn.hutool.core.date.DateUtil;
+import com.p6spy.engine.spy.appender.MessageFormattingStrategy;
+import org.apache.commons.lang3.StringUtils;
+
+import java.time.LocalDateTime;
+
+/**
+ * 自定义 p6spy sql输出格式
+ *
+ * @author MrBird
+ */
+public class P6spySqlFormatConfigure implements MessageFormattingStrategy {
+
+    @Override
+    public String formatMessage(int connectionId, String now, long elapsed, String category, String prepared, String sql, String url) {
+        return StringUtils.isNotBlank(sql) ? DateUtil.format(LocalDateTime.now(), "yyyy-MM-dd HH:mm:ss")
+                + " | 耗时 " + elapsed + " ms | SQL 语句:" + StringUtils.LF + sql.replaceAll("[\\s]+", StringUtils.SPACE) + ";" : StringUtils.EMPTY;
+    }
+}
diff --git a/src/main/java/com/xcong/farmer/cms/modules/system/controller/AdminCommonController.java b/src/main/java/com/xcong/farmer/cms/modules/system/controller/AdminCommonController.java
index d2f9eae..4216c52 100644
--- a/src/main/java/com/xcong/farmer/cms/modules/system/controller/AdminCommonController.java
+++ b/src/main/java/com/xcong/farmer/cms/modules/system/controller/AdminCommonController.java
@@ -1,5 +1,8 @@
 package com.xcong.farmer.cms.modules.system.controller;
 
+import cn.hutool.core.img.Img;
+import cn.hutool.core.img.ImgUtil;
+import cn.hutool.core.io.FileUtil;
 import cn.hutool.core.util.IdUtil;
 import com.xcong.farmer.cms.common.contants.AppContants;
 import com.xcong.farmer.cms.common.response.Result;
@@ -8,15 +11,20 @@
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import lombok.extern.slf4j.Slf4j;
+import net.coobird.thumbnailator.Thumbnails;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.web.bind.annotation.*;
 import org.springframework.web.multipart.MultipartFile;
 
 import javax.annotation.Resource;
+import javax.imageio.ImageIO;
 import javax.validation.Valid;
+import java.awt.image.BufferedImage;
 import java.io.File;
+import java.io.FileOutputStream;
 import java.io.IOException;
 
+import java.io.InputStream;
 import java.util.Map;
 
 
@@ -128,19 +136,38 @@
         if (!uploadDir.isDirectory()) {
             uploadDir.mkdir();
         }
-        //获得文件的后缀
+
+
+        // 获得文件的后缀
         String filename = IdUtil.simpleUUID() + file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf("."));
-        File filepath = new File(savePath + filename);
-        try {
-            //存文件
-            file.transferTo(filepath);
-        } catch (IOException e) {
-            e.printStackTrace();
+        if (isImage(file.getInputStream())) {
+            Thumbnails.of(file.getInputStream())
+                    // 图片大小(长宽)压缩比例 从0-1,1表示原图
+                    .scale(1f)
+                    // 图片质量压缩比例 从0-1,越接近1质量越好
+                    .outputQuality(0.5f)
+                    .toOutputStream(new FileOutputStream(savePath + filename));
+        } else {
+            File filepath = new File(savePath + filename);
+            try {
+                //存文件
+                file.transferTo(filepath);
+            } catch (IOException e) {
+                e.printStackTrace();
+            }
         }
+
         String visitPath = (saveUrl + filename);
         return Result.ok("上传成功",visitPath);
     }
 
-
-
+    private boolean isImage(InputStream inputStream) {
+        BufferedImage read = null;
+        try {
+            read = ImageIO.read(inputStream);
+        } catch (IOException e) {
+            return false;
+        }
+        return read != null;
+    }
 }
diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml
index c39852e..4d72940 100644
--- a/src/main/resources/application.yml
+++ b/src/main/resources/application.yml
@@ -10,6 +10,8 @@
     async:
       request-timeout: 20s
   datasource:
+    # 是否开启 SQL日志输出,生产环境建议关闭,有性能损耗
+    p6spy: true
     url: jdbc:mysql://120.27.238.55:3306/farmer_cms?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=GMT%2b8
     username: ct_test
     password: 123456
diff --git a/src/main/resources/spy.properties b/src/main/resources/spy.properties
new file mode 100644
index 0000000..2130078
--- /dev/null
+++ b/src/main/resources/spy.properties
@@ -0,0 +1,13 @@
+# p6spy\u914D\u7F6E\uFF0C\u6587\u6863 https://p6spy.readthedocs.io/en/latest/configandusage.html
+# \u4F7F\u7528\u65E5\u5FD7\u7CFB\u7EDF\u8BB0\u5F55 sql
+appender=com.p6spy.engine.spy.appender.Slf4JLogger
+# \u81EA\u5B9A\u4E49\u65E5\u5FD7\u6253\u5370
+logMessageFormat=com.xcong.farmer.cms.configurations.P6spySqlFormatConfigure
+# \u662F\u5426\u5F00\u542F\u6162 SQL\u8BB0\u5F55
+outagedetection=true
+# \u6162 SQL\u8BB0\u5F55\u6807\u51C6 2 \u79D2
+outagedetectioninterval=2
+# \u5F00\u542F\u8FC7\u6EE4
+filter=true
+# \u5305\u542B QRTZ\u7684\u4E0D\u6253\u5370
+exclude=QRTZ,select 1
\ No newline at end of file

--
Gitblit v1.9.1