From 1668fe1b912d07191c9fd7f20808d7d2162bc8e8 Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期一, 21 四月 2025 17:09:53 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/dev' into dev --- ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OssController.java | 181 +++++++++++++++++++++++++++++++++++++-------- 1 files changed, 149 insertions(+), 32 deletions(-) diff --git a/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OssController.java b/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OssController.java index 6358f23..2329c8d 100644 --- a/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OssController.java +++ b/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OssController.java @@ -1,16 +1,18 @@ package com.ruoyi.worker.controller; -import com.ruoyi.common.core.constant.Constants; import com.ruoyi.common.core.domain.R; -import com.ruoyi.common.core.exception.GlobalException; +import com.ruoyi.common.core.domain.Result; import com.ruoyi.common.core.utils.GaoDeMapUtil; -import com.ruoyi.common.core.utils.ObsUploadUtil; -import com.ruoyi.worker.entity.Order; -import com.ruoyi.worker.service.OrderService; +import com.ruoyi.order.api.feignClient.OrderClient; +import com.ruoyi.worker.utils.FileImageWatermarkUtils; +import com.ruoyi.worker.utils.TencentCosUtil; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; @@ -18,7 +20,11 @@ import org.springframework.web.multipart.MultipartFile; import javax.annotation.Resource; -import java.io.IOException; +import java.time.LocalDateTime; +import java.time.format.DateTimeFormatter; +import java.util.concurrent.CompletableFuture; +import java.util.concurrent.atomic.AtomicReference; + /** * @author HJL @@ -28,10 +34,14 @@ @RestController @RequestMapping("/oss") @Api(tags = "师傅端-文件上传") +@Slf4j public class OssController { @Resource - private OrderService orderService; + private OrderClient orderClient; + @Resource + private TencentCosUtil tencentCosUtil; + @PostMapping("/upload") @ApiOperation(value = "文件上传", tags = "师傅端-文件上传") @@ -39,40 +49,147 @@ @ApiImplicitParam(value = "文件", name = "file", dataType = "MultipartFile", required = true) }) public R<String> upload(@RequestParam("file") MultipartFile file) { - try { - return R.ok(ObsUploadUtil.obsUpload(file), ""); - } catch (IOException e) { - return R.fail("文件上传失败!"); - } + return R.ok(tencentCosUtil.upLoadFile(file)); } @PostMapping("/uploadPhoto") - @ApiOperation(value = "师傅端-上传完工照片", tags = "公共-文件上传") + @ApiOperation(value = "师傅端-上传完工照片", tags = "师傅端-文件上传") @ApiImplicitParams({ @ApiImplicitParam(value = "照片", name = "file", dataType = "MultipartFile", required = true), @ApiImplicitParam(value = "订单id", name = "orderId", dataType = "Integer", required = true), @ApiImplicitParam(value = "师傅所在经度", name = "longitude", dataType = "String", required = true), @ApiImplicitParam(value = "师傅所在纬度", name = "latitude", dataType = "String", required = true) }) - public R<String> uploadPhoto(@RequestParam("file") MultipartFile file, @RequestParam String orderId, - @RequestParam String longitude, @RequestParam String latitude) { - // 校验经纬度 - Order order = orderService.lambdaQuery().eq(Order::getIsDelete, orderId).eq(Order::getIsDelete, 0).one(); - // 用户下单位置经纬度 - String orderPosition = order.getLongitude() + "," + order.getLatitude(); - // 师傅经纬度 - String workerPosition = longitude + "," + latitude; - // 师傅当前位置离用户下单位置具体距离 - Long distance = GaoDeMapUtil.getDistance(orderPosition, workerPosition).getDatas(); - // 上传时判断是否在下单位置附件,距离大于某个值则 不允许上传 - if (distance > Constants.THREE_THOUSAND) { - throw new GlobalException("您当前手机定位超出当前订单预约地址范围 3km,无法提供回收服务!"); - } - try { - return R.ok(ObsUploadUtil.obsUpload(file)); - } catch (IOException e) { - return R.fail("文件上传失败!"); - } + public R<Boolean> uploadPhoto(@RequestParam("file") MultipartFile file, @RequestParam String orderId, + @RequestParam String longitude, @RequestParam String latitude) { + return R.ok(tencentCosUtil.upLoadFile(file)); } +// @PostMapping(value = "/pic", produces = "application/json;charset=UTF-8") +// @ApiOperation(value = "文件上传加水印", tags = "师傅端-文件上传") +// @ApiImplicitParams({ +// @ApiImplicitParam(value = "文件", name = "file", dataType = "MultipartFile", required = true) +// }) +// public R<String> pic(@RequestParam("file") MultipartFile file,String longitude, +// String latitude) { +//// Result<String> address = GaoDeMapUtil.getAddress(longitude, latitude); +////// return R.fail(); +//// +//// // 获取当前时间 +//// +//// LocalDateTime date = LocalDateTime.now(); +//// +//// // 设置日期格式 +//// +//// DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"); +//// +//// // 通过format调用转换的方法 +//// +//// String dateWatermark = formatter.format(date); +////// System.err.println("==========="+LocalDateTime.now()); +//// log.error("==========="+LocalDateTime.now()); +//// +//// MultipartFile watermarkFile = FileImageWatermarkUtils.markWithContent(file,dateWatermark,address.getDatas()); +////// System.err.println("==========="+LocalDateTime.now()); +//// log.error("==========="+LocalDateTime.now()); +//// +//// +//// String url = tencentCosUtil.upLoadFile(watermarkFile); +////// String url = tencentCosUtil.upLoadFile(file); +//// log.error("==========="+LocalDateTime.now()); +//// return R.ok(url); +// +// +// // 参数校验 +// if (file == null || file.isEmpty()) { +// return R.fail("文件不能为空"); +// } +// if (longitude == null || longitude.isEmpty() || latitude == null || latitude.isEmpty()) { +// return R.fail("经纬度参数不能为空"); +// } +// +// try { +// // 获取地址信息 +// Result<String> addressResult = GaoDeMapUtil.getAddress(longitude, latitude); +// if (addressResult == null || addressResult.getDatas() == null) { +// return R.fail("无法获取地址信息"); +// } +// +// // 获取当前时间 +// LocalDateTime date = LocalDateTime.now(); +// DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"); +// String dateWatermark = formatter.format(date); +// log.info("===========" + dateWatermark); +// +// // 给图片加水印 +// MultipartFile watermarkFile = FileImageWatermarkUtils.markWithContent(file, dateWatermark, addressResult.getDatas()); +// log.info("水印添加成功"); +// +// // 上传到腾讯云COS +// String url = tencentCosUtil.upLoadFile(watermarkFile); +// log.info("文件上传成功,URL: " + url); +// +// return R.ok(url); +// } catch (Exception e) { +// log.error("文件上传加水印失败: ", e); +// return R.fail("文件上传加水印失败: " + e.getMessage()); +// } +// } + + @Autowired + private ThreadPoolTaskExecutor taskExecutor; + @PostMapping(value = "/pic", produces = "application/json;charset=UTF-8") + @ApiOperation(value = "文件上传加水印", tags = "师傅端-文件上传") + @ApiImplicitParams({ + @ApiImplicitParam(value = "文件", name = "file", dataType = "MultipartFile", required = true) + }) + public CompletableFuture<R<String>> pic(@RequestParam("file") MultipartFile file, String longitude, String latitude) { + System.out.println("文件上传加水印=====>"+longitude+"====>"+latitude); + // 参数校验 + if (file == null || file.isEmpty()) { + return CompletableFuture.completedFuture(R.fail("文件不能为空")); + } + + Result<String> datas = new Result<>(); + + if (longitude == null || longitude.isEmpty() || latitude == null || latitude.isEmpty()) { + datas.setDatas("地址获取失败"); + } + + return CompletableFuture.supplyAsync(() -> { + try { + // 获取地址信息 + Result<String> addressResult = GaoDeMapUtil.getAddress(longitude, latitude); + if (addressResult == null || addressResult.getDatas() == null) { + datas.setDatas("地址获取失败"); + }else { + datas.setDatas(addressResult.getDatas()); + } + + // 获取当前时间 + LocalDateTime date = LocalDateTime.now(); + DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"); + String dateWatermark = formatter.format(date); + log.info("===========" + dateWatermark); + + // 给图片加水印 + MultipartFile watermarkFile = FileImageWatermarkUtils.markWithContent(file, dateWatermark, datas.getDatas()); + log.info("水印添加成功"); + + // 上传到腾讯云COS + String url = tencentCosUtil.upLoadFile(watermarkFile); + log.info("文件上传成功,URL: " + url); + + return R.ok(url); + } catch (Exception e) { + log.error("文件上传加水印失败: ", e); + return R.fail("文件上传加水印失败: " + e.getMessage()); + } + }, taskExecutor); + } + + + + + } -- Gitblit v1.7.1