From 527f4fd86eafb17dea8b9589b269da531299a6e5 Mon Sep 17 00:00:00 2001 From: zhangnaisong <2434969829@qq.com> Date: 星期五, 02 二月 2024 15:12:08 +0800 Subject: [PATCH] 三一车辆追踪线程加入sessionId修改提交 --- ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java | 127 ++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 120 insertions(+), 7 deletions(-) diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java index 03de3dd..fced250 100644 --- a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java +++ b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java @@ -15,7 +15,11 @@ import com.alibaba.fastjson.JSON; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.dtflys.forest.annotation.Var; import com.github.pagehelper.PageInfo; +import com.ruoyi.app.application.domain.ArdAppApplication; +import com.ruoyi.app.application.mapper.ArdAppApplicationMapper; +import com.ruoyi.app.position.mapper.ArdAppPositionMapper; import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.core.domain.entity.SysUser; import com.ruoyi.common.core.redis.RedisCache; @@ -24,6 +28,7 @@ import com.ruoyi.sy.domain.ArdAccessFence; import com.ruoyi.sy.param.ArdSyCarParam; import com.ruoyi.sy.vo.ArdSyCarVo; +import com.ruoyi.system.mapper.SysDeptMapper; import com.ruoyi.utils.gis.GisUtil; import com.ruoyi.utils.gis.Point; import com.ruoyi.scheduling.domian.SchedulingParam; @@ -87,6 +92,12 @@ RedisCache redisCache; @Resource private ArdSyCarDayMapper ardSyCarDayMapper; + + @Resource + private ArdAppApplicationMapper ardAppApplicationMapper; + + @Resource + private SysDeptMapper sysDeptMapper; @Value("${minio.endpoint}") private String minioEndpoint; @@ -923,15 +934,22 @@ @Override public Results chaseCarByCarId(String usersId, String carId, String cycle) { + String sessionId = ""; + for(String key : ONLINE_USER_SESSIONS.keySet()){ + if(key.startsWith(usersId + "_")){ + sessionId = key; + } + } + if(sessionId.equals("")){//娌℃湁session灏辫繑鍥炲け璐� + return Results.error("杩借釜澶辫触"); + } try { - /*Map<String,Map<String,Object>> map = new HashMap(); - map.put(carId,new HashMap()); - PositionContainer.getUserPositionMap().put(usersId,map);*/ if (cycle.equals("0")) { if (userCarTimerMap.get(usersId) != null) { userCarTimerMap.get(usersId).cancel(); userCarTimerMap.remove(usersId); PositionContainer.getUserPositionMap().remove(usersId); + System.out.println("鍋滄杩借釜"); } return Results.succeed("鍋滄杩借釜"); } else { @@ -943,7 +961,7 @@ map.put(carId, new HashMap()); PositionContainer.getUserPositionMap().put(usersId, map); Date date = new Date(); - Timer carPositionTimer = new Timer();//瀹氭椂鎺ㄩ�佸疄鏃朵綅缃� + Timer carPositionTimer = new Timer(sessionId);//瀹氭椂鎺ㄩ�佸疄鏃朵綅缃� TimerTask carPositionTask = new TimerTask() { @Override public void run() { @@ -952,7 +970,16 @@ if (position.size() != 0) { Map<String, Map<String, Object>> data = new HashMap(); data.put("31000", position); - WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(usersId), JSON.toJSONString(data)); + String sessionId = Thread.currentThread().getName(); + if(ONLINE_USER_SESSIONS.get(sessionId) == null){//鐢ㄦ埛绂荤嚎閲婃斁璧勬簮 + if (userCarTimerMap.get(usersId) != null) { + userCarTimerMap.get(usersId).cancel(); + userCarTimerMap.remove(usersId); + PositionContainer.getUserPositionMap().remove(usersId); + System.out.println("鐢ㄦ埛绂荤嚎锛屽仠姝㈣拷韪�"); + } + } + WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(sessionId), JSON.toJSONString(data)); } } } @@ -965,7 +992,7 @@ map.put(carId, new HashMap()); PositionContainer.getUserPositionMap().put(usersId, map); Date date = new Date(); - Timer carPositionTimer = new Timer();//瀹氭椂鎺ㄩ�佸疄鏃朵綅缃� + Timer carPositionTimer = new Timer(sessionId);//瀹氭椂鎺ㄩ�佸疄鏃朵綅缃� TimerTask carPositionTask = new TimerTask() { @Override public void run() { @@ -974,7 +1001,16 @@ if (position.size() != 0) { Map<String, Map<String, Object>> data = new HashMap(); data.put("31000", position); - WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(usersId), JSON.toJSONString(data)); + String sessionId = Thread.currentThread().getName(); + if(ONLINE_USER_SESSIONS.get(sessionId) == null){//鐢ㄦ埛绂荤嚎閲婃斁璧勬簮 + if (userCarTimerMap.get(usersId) != null) { + userCarTimerMap.get(usersId).cancel(); + userCarTimerMap.remove(usersId); + PositionContainer.getUserPositionMap().remove(usersId); + System.out.println("鐢ㄦ埛绂荤嚎锛屽仠姝㈣拷韪�"); + } + } + WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(sessionId), JSON.toJSONString(data)); } } } @@ -1304,4 +1340,81 @@ return sYClient.getAlarmHPfmCountDetail(syURL,carId,sessionId,startTime,endTime); } + @Override + public Map<String, Object> getOnlineSYCarPosition(String soilderId) { + Map<String,Object> result = new HashMap(); + ArdSyUser ardSyUserPara = new ArdSyUser(); + ardSyUserPara.setSysUserId(soilderId); + List<ArdSyUser> ardSyUserList = ardSyUserMapper.selectArdSyUserList(ardSyUserPara); + if(ardSyUserList.size() == 0){ + result.put("code","0"); + result.put("msg","鐧诲綍鐢ㄦ埛鏈寕鎺ヤ笁涓�杞﹁締璐﹀彿"); + result.put("SYCarPositionList",new ArrayList()); + return result; + } + ArdAppApplication ardAppApplicationPara = new ArdAppApplication(); + ardAppApplicationPara.setSoilderId(soilderId); + ardAppApplicationPara.setApplicationType("SYCar"); + ardAppApplicationPara.setState("1"); + List<ArdAppApplication> ardAppApplicationList = ardAppApplicationMapper.selectArdAppApplicationList(ardAppApplicationPara); + if(ardAppApplicationList.size() == 0){ + result.put("code","0"); + result.put("msg","鐧诲綍鐢ㄦ埛鏈粡鎸囨尌绔悓鎰�"); + result.put("SYCarPositionList",new ArrayList()); + return result; + } + SysUser sysUser = userMapper.selectUserById(soilderId);//鑾峰彇绯荤粺鐢ㄦ埛 + List<Long> deptIdList = new ArrayList(); + deptIdList.add(sysUser.getDeptId()); + deptIdList = getOwnAndChildrenDeptIdList(deptIdList,new ArrayList());//閫掑綊鏌ヨ涓嬪睘閮ㄩ棬涓婚敭 + List<String> carIdList = ardSyCarMapper.selectArdSyCarByDeptIds(deptIdList); + String carIds = ""; + for(String carId : carIdList){ + carIds = carIds + carId + ","; + } + carIds = carIds.substring(0,carIds.length() - 1); + String syURL = ""; + List<SysConfig> sysConfigResult = sysConfigMapper.selectByType("syCarPT"); + if(sysConfigResult.size() > 0){ + syURL = sysConfigResult.get(0).getConfigValue(); + }else{ + result.put("code","0"); + result.put("msg","涓変竴杞﹁締url娌℃湁褰曞叆"); + result.put("SYCarPositionList",new ArrayList()); + return result; + } + String passwordMd5 = DigestUtils.md5Hex(ardSyUserList.get(0).getPassword()); + Map<String,Object> syLoginResult = sYClient.logIn(syURL, passwordMd5, ardSyUserList.get(0).getUserId()); + String sessionId = (String) syLoginResult.get("sessionId"); + Map<String,Object> carNearPositionResult = sYClient.getCarNearPositionByCarId(syURL, carIds, ardSyUserList.get(0).getUserId(),sessionId); + if(((String)carNearPositionResult.get("rspCode")).equals("1")){ + result.put("code","1"); + result.put("msg","涓変竴杞﹁締鏌ヨ鎴愬姛"); + List<Map<String,Object>> SYCarPositionList = (List<Map<String, Object>>) carNearPositionResult.get("list"); + //绛涢�夊湪绾� + SYCarPositionList = SYCarPositionList.stream().filter(map -> ((String)map.get("stateCn")).startsWith("鍦ㄧ嚎")).collect(Collectors.toList()); + for(Map<String,Object> sycar : SYCarPositionList){ + Map<String,Object> map = ardSyCarMapper.getArdSyCarAndDeptByCarId((String)sycar.get("carId")); + sycar.putAll(map); + } + result.put("SYCarPositionList",SYCarPositionList); + return result; + }else{ + result.put("code","0"); + result.put("msg","涓変竴杞﹁締鏌ヨ澶辫触"); + result.put("SYCarPositionList",new ArrayList()); + return result; + } + } + + public List<Long> getOwnAndChildrenDeptIdList(List<Long> deptIdList,List<Long> deptIdListr){ + deptIdListr.addAll(deptIdList); + List<Long> result = sysDeptMapper.getChildrenDeptIdList(deptIdList); + if(result.size() != 0){ + deptIdListr.addAll(result); + result = getOwnAndChildrenDeptIdList(result,deptIdListr); + } + deptIdListr = deptIdListr.stream().distinct().collect(Collectors.toList()); + return deptIdListr; + } } -- Gitblit v1.9.3