From b30e1a48f2bc5f65a0efd2e69e090fed2d7a627c Mon Sep 17 00:00:00 2001 From: yanghui <2536613402@qq.com> Date: 星期四, 17 十一月 2022 15:56:43 +0800 Subject: [PATCH] #feat 订单退款和查询 --- springcloud_k8s_panzhihuazhihuishequ/applets/src/main/java/com/panzhihua/applets/api/CommonApi.java | 176 ++++++++++++++++++++++++++++++++++++++++------------------ 1 files changed, 121 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 8c4ba82..f76bf1c 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,6 +1,33 @@ package com.panzhihua.applets.api; -import cn.binarywang.wx.miniapp.api.WxMaSecCheckService; +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 cn.hutool.core.util.StrUtil; +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; +import org.springframework.data.redis.core.ValueOperations; +import org.springframework.util.ObjectUtils; +import org.springframework.web.bind.annotation.*; +import org.springframework.web.multipart.MultipartFile; + import com.alibaba.fastjson.JSON; import com.panzhihua.applets.config.WxMaConfiguration; import com.panzhihua.common.constants.Constants; @@ -12,28 +39,13 @@ 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 org.apache.commons.lang3.RandomUtils; -import org.springframework.beans.factory.annotation.Value; -import org.springframework.data.redis.core.StringRedisTemplate; -import org.springframework.data.redis.core.ValueOperations; -import org.springframework.util.ObjectUtils; -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 static com.panzhihua.common.utlis.FileTypeUploadUtils.assertAllowed; /** * @program: springcloud_k8s_panzhihuazhihuishequ @@ -45,7 +57,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 登录用户名 @@ -62,42 +82,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); @@ -110,16 +135,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("图片内容违规"); -// } + // if (!b) { + // return R.fail("图片内容违规"); + // } } catch (Exception e) { log.error("微信审核图片出错【{}】", e.getMessage()); return R.fail("图片上传失败"); -// e.printStackTrace(); + // e.printStackTrace(); } sftp.uploadMore(FtpConstants.FTPFILEPATH_IDCARD, name, is); sftp.logout(); @@ -131,6 +156,44 @@ } + @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; + String fileName = minioUtil.uploadRetFileName(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"); + //上传完压缩图后把原图清理,防止文件服务器资源爆满 + if (StrUtil.isNotBlank(fileName)){ + minioUtil.removeMinio(fileName); + } + 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) { @@ -138,30 +201,33 @@ 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); } - @ApiOperation(value = "获取天气",response = WeatherVO.class) + @ApiOperation(value = "获取天气", response = WeatherVO.class) @GetMapping(value = "/getWeather/noToken") - public R getWeather(){ - //获取请求url + 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); + String result = HttpUtils.sendGet(url, param); return R.ok(JSON.parseObject(result)); } - - 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("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); + } + @ApiOperation("无水洗车下单接口") + @GetMapping("/wsPay") + public R wsPay(@RequestParam("orderid") String orderid,@RequestParam("openid")String openid,@RequestParam("amount")String amount){ + Map map=umfPayUtil.pay2(orderid, DateUtils.getCurrentDateString(),openid,amount); + return R.ok(map); } } -- Gitblit v1.7.1