From eb286b8d88dc5fcd0290d0d243cb7f0a2448616f Mon Sep 17 00:00:00 2001 From: luodangjia <luodangjia> Date: 星期四, 31 十月 2024 22:24:29 +0800 Subject: [PATCH] 8.9 --- ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java | 18 +++++++++++++++--- 1 files changed, 15 insertions(+), 3 deletions(-) diff --git a/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java b/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java index 0ac1fd6..c5874ab 100644 --- a/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java +++ b/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java @@ -1,6 +1,7 @@ package com.ruoyi.worker.controller; +import cn.afterturn.easypoi.cache.manager.IFileLoader; import com.alibaba.fastjson2.JSONObject; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.ruoyi.common.core.constant.Constants; @@ -41,8 +42,11 @@ import java.util.Map; import java.util.Optional; import java.util.Set; +import java.util.concurrent.TimeUnit; import java.util.stream.Collectors; import javax.annotation.Resource; + +import lombok.Synchronized; import org.springframework.transaction.annotation.Transactional; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; @@ -297,6 +301,7 @@ @ApiImplicitParam(value = "经度", name = "longitude", dataType = "Integer", required = true), @ApiImplicitParam(value = "纬度", name = "latitude", dataType = "Integer", required = true) }) + @Synchronized public R<Boolean> coordinate(@RequestParam Double longitude, @RequestParam Double latitude) { System.err.println("调用记录经纬度"+ LocalDateTime.now()); @@ -305,6 +310,13 @@ if (null == loginWorker) { return R.loginExpire("登录失效!"); } + Object cacheObject2 = redisService.getCacheObject("LOCK" + loginWorker.getUserid()); + if (cacheObject2!=null){ + return R.ok(); + }else { + redisService.setCacheObject("LOCK" + loginWorker.getUserid(),"1", 10L, TimeUnit.SECONDS); + } + // 获取当天时间 String today = DateUtils.dateTimeNow("yyyy-MM-dd"); Integer workerId = loginWorker.getUserid(); @@ -368,7 +380,7 @@ LocalDateTime now = LocalDateTime.now(); // 减去三十分钟 - LocalDateTime thirtyMinutesAgo = now.minusMinutes(10); + LocalDateTime thirtyMinutesAgo = now.minusMinutes(5); // 定义日期时间格式 DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm"); @@ -425,7 +437,7 @@ } - + redisService.deleteObject("LOCK" + loginWorker.getUserid()); return R.ok(); } @@ -435,7 +447,7 @@ // 检查差值是否小于等于2分钟 long minutes = Math.abs(duration.toMinutes()); - return minutes >= 10; + return minutes >= 5; } /** * 师傅端-定时调度记录师傅当天的轨迹标点 -- Gitblit v1.7.1