From 9acb17a6871d84a85c373eb90b980f98894e30e0 Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期二, 18 二月 2025 17:58:48 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'
---
ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java | 22 +++++++++++++++++-----
1 files changed, 17 insertions(+), 5 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..e93913d 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");
@@ -378,7 +390,7 @@
String nowStr = now.format(formatter);
- redisService.setCacheObject("MARK:"+workerId+":"+nowStr,longitude + "," + latitude);
+ redisService.setCacheObject("MARK:"+workerId+":"+nowStr,longitude + "," + latitude, 10L, TimeUnit.MINUTES);
String cacheObject = redisService.getCacheObject("MARK:" + workerId + ":" + formattedTime);
if (cacheObject!=null){
@@ -418,14 +430,14 @@
System.err.println("-----当前距离"+distance);
//如果超出一定范围,存入Mark文件
if (distance<50){
- redisService.setCacheObject("TIME:"+workerId,LocalDateTime.now());
+ redisService.setCacheObject("TIME:"+workerId,LocalDateTime.now(), 10L, TimeUnit.MINUTES);
marker(longitude,latitude);
}
}
}
-
+ 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