From 43f0578e80af82ecae6c61b51bd0539c6b960603 Mon Sep 17 00:00:00 2001
From: puhanshu <a9236326>
Date: 星期二, 16 八月 2022 19:08:32 +0800
Subject: [PATCH] 服务范围优化

---
 springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/api/CommonApi.java |  179 +++++++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 124 insertions(+), 55 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/api/CommonApi.java b/springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/api/CommonApi.java
index 29488d1..97945b0 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/api/CommonApi.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/api/CommonApi.java
@@ -1,17 +1,24 @@
 package com.panzhihua.applets.api;
 
-import cn.binarywang.wx.miniapp.api.WxMaSecCheckService;
-import com.panzhihua.applets.config.WxMaConfiguration;
-import com.panzhihua.common.constants.FtpConstants;
-import com.panzhihua.common.constants.UserConstants;
-import com.panzhihua.common.model.vos.R;
-import com.panzhihua.common.model.vos.user.UserPhoneVO;
-import com.panzhihua.common.service.community.CommunityService;
-import com.panzhihua.common.utlis.SFTPUtil;
-import io.swagger.annotations.Api;
-import io.swagger.annotations.ApiOperation;
-import lombok.extern.slf4j.Slf4j;
-import me.chanjar.weixin.common.error.WxErrorException;
+import java.io.File;
+import java.io.FileNotFoundException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.util.*;
+import java.util.concurrent.TimeUnit;
+import java.util.concurrent.atomic.AtomicBoolean;
+
+import javax.annotation.Resource;
+import javax.servlet.http.HttpServletRequest;
+
+import com.jcraft.jsch.SftpException;
+import com.panzhihua.applets.config.MinioUtil;
+import com.panzhihua.applets.umf.UmfPayUtil;
+import com.panzhihua.common.controller.BaseController;
+import com.panzhihua.common.utlis.DateUtils;
+import com.panzhihua.common.utlis.MimeTypeUtils;
+import net.coobird.thumbnailator.Thumbnails;
+import org.apache.commons.io.FilenameUtils;
 import org.apache.commons.lang3.RandomUtils;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.data.redis.core.StringRedisTemplate;
@@ -20,17 +27,24 @@
 import org.springframework.web.bind.annotation.*;
 import org.springframework.web.multipart.MultipartFile;
 
-import javax.annotation.Resource;
-import javax.servlet.http.HttpServletRequest;
-import java.io.File;
-import java.io.IOException;
-import java.io.InputStream;
-import java.util.Arrays;
-import java.util.Base64;
-import java.util.List;
-import java.util.UUID;
-import java.util.concurrent.TimeUnit;
-import java.util.concurrent.atomic.AtomicBoolean;
+import com.alibaba.fastjson.JSON;
+import com.panzhihua.applets.config.WxMaConfiguration;
+import com.panzhihua.common.constants.Constants;
+import com.panzhihua.common.constants.FtpConstants;
+import com.panzhihua.common.constants.UserConstants;
+import com.panzhihua.common.model.vos.R;
+import com.panzhihua.common.model.vos.community.WeatherVO;
+import com.panzhihua.common.model.vos.user.UserPhoneVO;
+import com.panzhihua.common.service.community.CommunityService;
+import com.panzhihua.common.utlis.HttpUtils;
+import com.panzhihua.common.utlis.SFTPUtil;
+
+import cn.binarywang.wx.miniapp.api.WxMaSecCheckService;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import lombok.extern.slf4j.Slf4j;
+
+import static com.panzhihua.common.utlis.FileTypeUploadUtils.assertAllowed;
 
 /**
  * @program: springcloud_k8s_panzhihuazhihuishequ
@@ -42,7 +56,15 @@
 @RestController
 @RequestMapping("/common/")
 @Api(tags = {"公共接口"})
-public class CommonApi {
+public class CommonApi extends BaseController {
+    /**
+     * 允许的图片文件后缀
+     */
+    private static List<String> fileExtensionAllow = Arrays.asList("gif", "jpg", "png", "jpeg");
+    /**
+     * 允许的视频文件后缀
+     */
+    private static List<String> videoExtensionAllow = Arrays.asList("mp4", "mov");
     @Resource
     private StringRedisTemplate stringRedisTemplate;
     // FTP 登录用户名
@@ -59,42 +81,47 @@
     private int port;
     @Value("${ftp.url}")
     private String url;
-
-    /**
-     * 允许的图片文件后缀
-     */
-    private static  List<String> fileExtensionAllow = Arrays.asList("gif", "jpg", "png", "jpeg");
-    /**
-     * 允许的视频文件后缀
-     */
-    private static  List<String> videoExtensionAllow = Arrays.asList("mp4", "mov");
-
+    @Value("${minio.url}")
+    private String minUrl;
     @Resource
     private WxMaConfiguration wxMaConfiguration;
     @Resource
     private CommunityService communityService;
+    @Resource
+    private MinioUtil minioUtil;
+    @Resource
+    private UmfPayUtil umfPayUtil;
+
+    public static void main(String[] args) {
+        // int nextInt = RandomUtils.nextInt(99999, 1000000);
+        // System.out.println(nextInt);
+        String basicStr =
+            "2092261934651932672" + ":" + "de1c0dbb-9197-4724-9cc2-aa94e30a072f" + ":" + System.currentTimeMillis();
+        String s = Base64.getEncoder().encodeToString(basicStr.getBytes());
+        System.out.println(s);
+
+    }
 
     @ApiOperation(value = "上传照片/视频 (jpg/jpeg/png/mp4/mov)")
     @PostMapping(value = "uploadimage", consumes = "multipart/*", headers = "content-type=multipart/form-date")
     public R uploadImage(@RequestParam MultipartFile file, HttpServletRequest request) throws IOException {
-//        微信图片内容校验
-        WxMaSecCheckService wxMaSecCheckService = wxMaConfiguration.getMaService().getSecCheckService();
+        // 微信图片内容校验
+        WxMaSecCheckService wxMaSecCheckService = wxMaConfiguration.getMaService(this.getAppId()).getSecCheckService();
         String property = System.getProperty("user.dir");
 
         String fileExtension = ".jpg";
 
         String originName = file.getOriginalFilename();
         AtomicBoolean isVideo = new AtomicBoolean(false);
-        videoExtensionAllow.forEach(ext ->{
+        videoExtensionAllow.forEach(ext -> {
             String originNameLowerCase = originName.toLowerCase();
-            if(originNameLowerCase.endsWith("." +ext)){
+            if (originNameLowerCase.endsWith("." + ext)) {
                 isVideo.set(true);
             }
         });
-        if(isVideo.get()){
+        if (isVideo.get()) {
             fileExtension = ".mp4";
         }
-
 
         String fileName = property + File.separator + UUID.randomUUID().toString().replace("-", "") + fileExtension;
         File file1 = new File(fileName);
@@ -107,15 +134,16 @@
             InputStream is = file.getInputStream();
             file.transferTo(file1);
             try {
-                boolean b = wxMaSecCheckService.checkImage(file1);
+                // boolean b = wxMaSecCheckService.checkImage(file1);
                 boolean delete = file1.delete();
                 log.info("临时文件删除【{}】", delete);
-                if (!b) {
-                    return R.fail("图片内容违规");
-                }
-            } catch (WxErrorException e) {
+                // if (!b) {
+                // return R.fail("图片内容违规");
+                // }
+            } catch (Exception e) {
                 log.error("微信审核图片出错【{}】", e.getMessage());
-                e.printStackTrace();
+                return R.fail("图片上传失败");
+                // e.printStackTrace();
             }
             sftp.uploadMore(FtpConstants.FTPFILEPATH_IDCARD, name, is);
             sftp.logout();
@@ -127,6 +155,40 @@
 
     }
 
+    @ApiOperation(value = "新上传照片接口")
+    @PostMapping(value = "/uploadimages", consumes = "multipart/*", headers = "content-type=multipart/form-date")
+    public R uploadImages(@RequestParam MultipartFile file, HttpServletRequest request) {
+        try {
+            assertAllowed(file, MimeTypeUtils.DEFAULT_ALLOWED_EXTENSION);
+            String extension = FilenameUtils.getExtension(file.getOriginalFilename());
+            String name = UUID.randomUUID().toString().replaceAll("-", "") + "." + extension;
+            String imageUrl = minioUtil.upload(file, name);
+            return R.ok(imageUrl);
+        } catch (Exception e) {
+            log.error("上传照片失败【{}】", e.getMessage());
+            return R.fail();
+        }
+    }
+
+    @ApiOperation(value = "新上传照片压缩接口")
+    @PostMapping(value = "/uploadimagescompress", consumes = "multipart/*", headers = "content-type=multipart/form-date")
+    public R uploadImagesComPress(@RequestParam MultipartFile file, HttpServletRequest request) {
+        try {
+            assertAllowed(file, MimeTypeUtils.DEFAULT_ALLOWED_EXTENSION);
+            String extension = FilenameUtils.getExtension(file.getOriginalFilename());
+            String uuid=UUID.randomUUID().toString().replaceAll("-", "");
+            String name = uuid  + "."+ extension;
+            minioUtil.upload(file, name);
+            Thumbnails.of(file.getInputStream()).scale(0.5).outputQuality(0.71).outputFormat("jpg").toFile(uuid+"_compress");
+            File file1=new File(uuid+"_compress.jpg");
+            String imageUrl = minioUtil.uploadFile(file1, uuid+"_compress.jpg");
+            return R.ok(imageUrl);
+        } catch (Exception e) {
+            log.error("上传照片失败【{}】", e.getMessage());
+            return R.fail();
+        }
+    }
+
     @ApiOperation(value = "发送验证码")
     @PostMapping(value = "smscode")
     public R smscode(@RequestBody UserPhoneVO userPhoneVO) {
@@ -134,20 +196,27 @@
         if (ObjectUtils.isEmpty(newPhone)) {
             return R.fail("新手机号不能为空");
         }
-        //todo 发送验证码接第三方
+        // todo 发送验证码接第三方
         int nextInt = RandomUtils.nextInt(99999, 1000000);
         ValueOperations<String, String> valueOperations = stringRedisTemplate.opsForValue();
         valueOperations.set(UserConstants.PHONE_PUT + newPhone, nextInt + "", 3, TimeUnit.MINUTES);
         return R.ok(nextInt);
     }
 
-
-    public static void main(String[] args) {
-//        int nextInt = RandomUtils.nextInt(99999, 1000000);
-//        System.out.println(nextInt);
-        String basicStr = "2092261934651932672" + ":" + "de1c0dbb-9197-4724-9cc2-aa94e30a072f" + ":" + System.currentTimeMillis();
-        String s = Base64.getEncoder().encodeToString(basicStr.getBytes());
-        System.out.println(s);
-
+    @ApiOperation(value = "获取天气", response = WeatherVO.class)
+    @GetMapping(value = "/getWeather/noToken")
+    public R getWeather() {
+        // 获取请求url
+        String url = Constants.G_D_WEATHER_URL;
+        // 获取请求参数
+        String param = "key=" + Constants.G_D_WEATHER_KEY + "&city=510400";
+        String result = HttpUtils.sendGet(url, param);
+        return R.ok(JSON.parseObject(result));
+    }
+    @ApiOperation("uu洗车下单接口")
+    @GetMapping("/uuPay")
+    public R uuPay(@RequestParam("orderid") String orderid,@RequestParam("openid")String openid,@RequestParam("amount")String amount){
+        Map map=umfPayUtil.pay(orderid, DateUtils.getCurrentDateString(),openid,amount);
+        return R.ok(map);
     }
 }

--
Gitblit v1.7.1