From 10ad2e710d2bd52aac31d5d63a7bb6beae76b6a8 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Tue, 07 Nov 2023 14:35:32 +0800
Subject: [PATCH] 用户列表增加搜索条件

---
 src/main/java/cc/mrbird/febs/mall/controller/CommonController.java |  102 +++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 94 insertions(+), 8 deletions(-)

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 0c1db62..752a2bc 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/CommonController.java
@@ -1,23 +1,28 @@
 package cc.mrbird.febs.mall.controller;
 
+import cc.mrbird.febs.common.annotation.ControllerEndpoint;
 import cc.mrbird.febs.common.entity.FebsResponse;
 import cc.mrbird.febs.common.exception.FebsException;
-import cc.mrbird.febs.common.utils.AppContants;
-import cc.mrbird.febs.common.utils.RedisUtils;
-import cc.mrbird.febs.common.utils.SubMailSend;
-import cc.mrbird.febs.common.utils.ZzSmsSend;
+import cc.mrbird.febs.common.utils.*;
+import cc.mrbird.febs.mall.dto.AccountAndCodeDto;
+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.util.IdUtil;
 import cn.hutool.core.util.StrUtil;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import io.swagger.annotations.ApiParam;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
-import org.springframework.web.bind.annotation.GetMapping;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RequestParam;
-import org.springframework.web.bind.annotation.RestController;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+import org.springframework.web.multipart.MultipartFile;
+import sun.misc.BASE64Encoder;
 
+import java.io.IOException;
 import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
 
 /**
@@ -25,6 +30,7 @@
  * @date 2021-09-16
  **/
 @Slf4j
+@CrossOrigin("*")
 @RestController
 @RequestMapping(value = "/api/common")
 @RequiredArgsConstructor
@@ -32,6 +38,7 @@
 public class CommonController {
 
     private final RedisUtils redisUtils;
+    private final ICommonService commonService;
 
     @ApiOperation(value = "获取验证码接口", notes = "获取验证码通用接口")
     @GetMapping(value = "/verifyCode")
@@ -68,4 +75,83 @@
         }
         return new FebsResponse().fail().message("验证码发送失败");
     }
+
+    /**
+     *  图片上传
+     * @return
+     */
+    @PostMapping(value = "/uploadFileBase64")
+    @ControllerEndpoint(operation = "图片上传", exceptionMessage = "上传失败")
+    public Map<String,Object> uploadFileBase64(@RequestBody @Validated MultipartFile file) {
+        if (file == null || file.isEmpty()) {
+            return new FebsResponse().message("上传文件为空");
+        }
+
+        //文件加密
+        BASE64Encoder base64Encoder =new BASE64Encoder();
+        String base64EncoderImg = null;
+        try {
+            base64EncoderImg = base64Encoder.encode(file.getBytes());
+        } catch (IOException e) {
+            e.printStackTrace();
+        }
+
+        String imageFuffix = ".png";
+        String imageNames = System.currentTimeMillis() + IdUtil.simpleUUID() + imageFuffix;
+        String imageName = "uploadeFile/" + imageNames;
+        OssUtils.uploadFileWithBase64(base64EncoderImg, imageName);
+        String bucket_name ="https://excoin.oss-cn-hangzhou.aliyuncs.com";
+        String url = bucket_name + "/" + imageName;
+
+        Map<String,Object> map = new HashMap<String,Object>();
+        Map<String,Object> map2 = new HashMap<String,Object>();
+        map.put("code",0);//0表示成功,1失败
+        map.put("msg","上传成功");//提示消息
+        map.put("data",map2);
+        map2.put("src",url);//图片url
+        map2.put("title",imageNames);//图片名称,这个会显示在输入框里
+        return map;
+    }
+
+    @ApiOperation(value = "数据字典")
+    @GetMapping(value = "/findDataDic/{type}")
+    public FebsResponse findDataDic(@PathVariable("type") String type) {
+        List<DataDictionaryCustom> dic = commonService.findDataDicByType(type);
+        return new FebsResponse().success().data(dic);
+    }
+
+    @ApiOperation(value = "base64上传")
+    @PostMapping(value = "/base64Upload")
+    public FebsResponse base64Upload(@RequestBody @Validated Base64UploadDto base64UploadDto) {
+        String base64Str = base64UploadDto.getBase64Str();
+        if (base64Str.startsWith("data:image")) {
+            base64Str = base64Str.substring(base64Str.indexOf(",") + 1, base64Str.length() - 1);
+        }
+
+        String imageFuffix = ".jpg";
+        String imageNames = System.currentTimeMillis() + IdUtil.simpleUUID() + imageFuffix;
+        String imageName = "uploadeFile/" + imageNames;
+        OssUtils.uploadFileWithBase64(base64Str, imageName);
+        String bucket_name ="https://excoin.oss-cn-hangzhou.aliyuncs.com";
+        String url = bucket_name + "/" + imageName;
+
+        return new FebsResponse().message("上传成功").success().data(url);
+    }
+
+    @ApiOperation(value = "获取版本信息")
+    @GetMapping(value = "/appVersion")
+    public FebsResponse appVersion() {
+        return new FebsResponse().message("获取成功").success().data(commonService.findAppVersion());
+    }
+
+    @ApiOperation(value = "验证验证码接口")
+    @PostMapping(value = "/checkCode")
+    public FebsResponse checkCode(@RequestBody AccountAndCodeDto accountAndCodeDto) {
+
+        boolean flag = commonService.verifyCode(accountAndCodeDto.getAccount(), accountAndCodeDto.getCode());
+        if (flag) {
+            return new FebsResponse().success();
+        }
+        return new FebsResponse().fail().message("验证码错误");
+    }
 }

--
Gitblit v1.9.1