From b87c5549fe471167882192944db3f2d6b729476c Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Fri, 15 Mar 2024 14:13:55 +0800
Subject: [PATCH] 抽奖

---
 src/main/java/cc/mrbird/febs/mall/controller/AdminMallGoodsController.java |  132 +++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 117 insertions(+), 15 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/controller/AdminMallGoodsController.java b/src/main/java/cc/mrbird/febs/mall/controller/AdminMallGoodsController.java
index 8e8f1d1..be8e374 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/AdminMallGoodsController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/AdminMallGoodsController.java
@@ -7,21 +7,34 @@
 import cc.mrbird.febs.common.entity.QueryRequest;
 import cc.mrbird.febs.common.utils.OssUtils;
 import cc.mrbird.febs.mall.dto.AddMallGoodsDto;
+import cc.mrbird.febs.mall.dto.MallGoodsUpdateDto;
 import cc.mrbird.febs.mall.dto.UpMallGoodsDto;
 import cc.mrbird.febs.mall.entity.MallGoods;
 import cc.mrbird.febs.mall.entity.MallGoodsCategory;
+import cc.mrbird.febs.mall.entity.TzInfo;
 import cc.mrbird.febs.mall.service.IAdminMallGoodsService;
+import cc.mrbird.febs.mall.vo.AdminMallGoodsCategoryTreeVo;
+import cc.mrbird.febs.mall.vo.AdminMallGoodsTreeVo;
+import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.util.IdUtil;
+import cn.hutool.core.util.StrUtil;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
+import net.coobird.thumbnailator.Thumbnails;
 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 javax.validation.Valid;
+import javax.validation.constraints.NotNull;
+import java.awt.image.BufferedImage;
+import java.io.ByteArrayOutputStream;
 import java.io.IOException;
+import java.util.ArrayList;
 import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
 
 @Slf4j
@@ -43,17 +56,38 @@
         if (file.isEmpty()) {
             new FebsResponse().message("上传文件为空");
         }
-
-        //文件加密
+        String base64EncoderImg = "";
         BASE64Encoder base64Encoder =new BASE64Encoder();
-        String base64EncoderImg = null;
-        try {
-            base64EncoderImg = base64Encoder.encode(file.getBytes());
-        } catch (IOException e) {
-            e.printStackTrace();
+        List<String> imageFuffixStr = CollUtil.toList(StrUtil.split(file.getOriginalFilename(), "."));
+        String imageFuffix = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf("."));
+        if("jpg".equals(imageFuffixStr.get(1))){
+            try {
+                //输出到BufferedImage
+                BufferedImage bufferedImage = Thumbnails.of(file.getInputStream())
+                        // 图片大小(长宽)压缩比例 从0-1,1表示原图
+                        .scale(1f)
+                        // 图片质量压缩比例 从0-1,越接近1质量越好
+                        .outputQuality(0.5f)
+                        .asBufferedImage();
+                //对内存中的图片文件进行Base64处理
+                ByteArrayOutputStream newBaos = new ByteArrayOutputStream();//io流
+                ImageIO.write(bufferedImage, "jpg", newBaos);//写入流中
+                byte[] bytes = newBaos.toByteArray();//转换成字节
+                base64EncoderImg = base64Encoder.encode(bytes);
+//            base64EncoderImg = URLEncoder.encode(new BASE64Encoder().encode(bytes), "UTF-8");
+            } catch (Exception e) {
+                e.printStackTrace();
+            }
+        }else{
+            try {
+                base64EncoderImg = base64Encoder.encode(file.getBytes());
+            } catch (IOException e) {
+                e.printStackTrace();
+            }
         }
-
-        String imageFuffix = ".png";
+        //文件加密
+//        String imageFuffix = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf("."));
+//      String imageFuffix = ".png";
         String imageNames = System.currentTimeMillis() + IdUtil.simpleUUID() + imageFuffix;
         String imageName = "uploadeFile/" + imageNames;
         OssUtils.uploadFileWithBase64(base64EncoderImg, imageName);
@@ -68,6 +102,26 @@
         map2.put("src",url);//图片url
         map2.put("title",imageNames);//图片名称,这个会显示在输入框里
         return map;
+    }
+
+    /**
+     * 商品列表
+     * @param request
+     * @return
+     */
+    @GetMapping("tzList")
+    public FebsResponse getTzList(TzInfo tzInfo, QueryRequest request) {
+        Map<String, Object> data = getDataTable(adminMallGoodsService.getTzListInPage(tzInfo, request));
+        return new FebsResponse().success().data(data);
+    }
+
+    /**
+     * 商品-编辑
+     */
+    @PostMapping("tzUpdate")
+    @ControllerEndpoint(operation = "商品-编辑", exceptionMessage = "操作失败")
+    public FebsResponse tzUpdate(TzInfo tzInfo) {
+        return adminMallGoodsService.tzUpdate(tzInfo);
     }
 
     /**
@@ -92,20 +146,68 @@
     }
 
     /**
+     * 商品-热卖
+     */
+    @GetMapping("goodsHot/{id}")
+    @ControllerEndpoint(operation = " 商品-热卖", exceptionMessage = "设置失败")
+    public FebsResponse goodsHot(@NotNull(message = "{required}") @PathVariable Long id) {
+        return adminMallGoodsService.goodsHot(id);
+    }
+
+    /**
+     * 商品-取消热卖
+     */
+    @GetMapping("goodsNotHot/{id}")
+    @ControllerEndpoint(operation = " 商品-取消热卖", exceptionMessage = "设置失败")
+    public FebsResponse goodsNotHot(@NotNull(message = "{required}") @PathVariable Long id) {
+        return adminMallGoodsService.goodsNotHot(id);
+    }
+
+    /**
      * 商品-上架
      */
-    @PostMapping("upMallGoods")
+    @GetMapping("upMallGoods/{id}")
     @ControllerEndpoint(operation = " 商品-上架", exceptionMessage = "上架失败")
-    public FebsResponse upMallGoods(@RequestBody @Valid UpMallGoodsDto upMallGoodsDto) {
-        return adminMallGoodsService.upMallGoods(upMallGoodsDto);
+    public FebsResponse upMallGoods(@NotNull(message = "{required}") @PathVariable Long id) {
+        return adminMallGoodsService.upMallGoods(id);
     }
 
     /**
      * 商品-下架
      */
-    @PostMapping("downMallGoods")
+    @GetMapping("downMallGoods/{id}")
     @ControllerEndpoint(operation = " 商品-下架", exceptionMessage = "下架失败")
-    public FebsResponse downMallGoods(@RequestBody @Valid UpMallGoodsDto upMallGoodsDto) {
-        return adminMallGoodsService.downMallGoods(upMallGoodsDto);
+    public FebsResponse downMallGoods(@NotNull(message = "{required}") @PathVariable Long id) {
+        return adminMallGoodsService.downMallGoods(id);
     }
+
+    /**
+     * 商品-删除
+     */
+    @GetMapping("delMallGoods/{id}")
+    @ControllerEndpoint(operation = " 商品-删除", exceptionMessage = "删除失败")
+    public FebsResponse delMallGoods(@NotNull(message = "{required}") @PathVariable Long id) {
+        return adminMallGoodsService.delMallGoods(id);
+    }
+
+
+    /**
+     * 商品-编辑
+     */
+    @PostMapping("updateMallGoods")
+    @ControllerEndpoint(operation = "商品-编辑", exceptionMessage = "操作失败")
+    public FebsResponse updateMallGoods(@RequestBody @Valid MallGoodsUpdateDto mallGoodsUpdateDto) {
+        return adminMallGoodsService.updateMallGoods(mallGoodsUpdateDto);
+    }
+
+    /**
+     * 商品-全部选择
+     */
+    @GetMapping("goods/allTree")
+    @ControllerEndpoint(exceptionMessage = "获取商品失败")
+    public List<AdminMallGoodsTreeVo> getAllGoodsTree(){
+        return adminMallGoodsService.getAllGoodsTree();
+    }
+
+
 }

--
Gitblit v1.9.1