From 38f29e38fcc668171dc05c53d40a36b895c86102 Mon Sep 17 00:00:00 2001 From: liusuyi <1951119284@qq.com> Date: 星期四, 10 十月 2024 13:34:28 +0800 Subject: [PATCH] init --- ard-work/src/main/java/com/ruoyi/app/position/service/impl/AppPositionPushService.java | 135 ++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 120 insertions(+), 15 deletions(-) diff --git a/ard-work/src/main/java/com/ruoyi/app/position/service/impl/AppPositionPushService.java b/ard-work/src/main/java/com/ruoyi/app/position/service/impl/AppPositionPushService.java index 5fad187..a993ad1 100644 --- a/ard-work/src/main/java/com/ruoyi/app/position/service/impl/AppPositionPushService.java +++ b/ard-work/src/main/java/com/ruoyi/app/position/service/impl/AppPositionPushService.java @@ -1,5 +1,6 @@ package com.ruoyi.app.position.service.impl; +import com.alibaba.fastjson2.JSONObject; import com.ruoyi.app.position.domain.ArdAppPosition; import com.ruoyi.app.position.service.IArdAppPositionService; import com.ruoyi.common.core.domain.entity.SysUser; @@ -26,11 +27,7 @@ public static Map<String, List<ArdAppPosition>> tempDataMap = new HashMap<>();//涓存椂鏁版嵁 姣忎釜鐢ㄦ埛鍏宠仈 public static Map<String, Timer> userTimerMap = new HashMap();//瀹氭椂鍣� 姣忎釜鐢ㄦ埛鍏宠仈 public static Map<String, Timer> tempUserTimerMap = new HashMap();//涓存椂瀹氭椂鍣� 姣忎釜鐢ㄦ埛鍏宠仈 - public static List<ArdAppPosition> initDataList; - - static { - initDataList = getAppPositionList(); - } +// public static List<ArdAppPosition> initDataList; //鍚姩鍏ㄥ眬瀹氭椂鍣� public static Timer startTimerTask(String userId, Integer period) { @@ -39,9 +36,10 @@ @Override public void run() { List<ArdAppPosition> data = dataMap.get(userId); - if (data.size() > 0) { + List<ArdAppPosition> onlineData = isOnlie(data); + if (onlineData.size() > 0) { Map newMap = new HashMap<>(); - newMap.put("50000", data); + newMap.put("50000", onlineData); WebSocketUtils.sendMessage(WebSocketUtils.ONLINE_USER_SESSIONS.get(userId), newMap); } } @@ -58,9 +56,10 @@ public void run() { //寰幆 List<ArdAppPosition> data = tempDataMap.get(userId); - if (data.size() > 0) { + List<ArdAppPosition> onlineData = isOnlie(data); + if (onlineData.size() > 0) { Map newMap = new HashMap<>(); - newMap.put("50000", data); + newMap.put("50000", onlineData); WebSocketUtils.sendMessage(WebSocketUtils.ONLINE_USER_SESSIONS.get(userId), newMap); } } @@ -73,7 +72,6 @@ public static void stopTimerTask(Timer timer) { if (timer != null) { timer.cancel(); - log.info("鍋滄杩愯"); } } @@ -83,15 +81,122 @@ ISysUserService sysUserService = SpringUtils.getBean(ISysUserService.class); //鑾峰彇鎵�鏈塧pp鐢ㄦ埛 List<SysUser> list = sysUserService.selectAllAppUserList(new SysUser()); - List<SysUser> onlineList = list.stream() - .filter(obj -> obj.getAppOnlineState().equals("1")) - .collect(Collectors.toList()); - for (SysUser sysUser : onlineList) { +// List<SysUser> onlineList = list.stream() +// .filter(obj -> obj.getAppOnlineState().equals("1")) +// .collect(Collectors.toList()); + for (SysUser sysUser : list) { IArdAppPositionService ardAppPositionService = SpringUtils.getBean(IArdAppPositionService.class); ArdAppPosition ardAppPosition = ardAppPositionService.selectLastArdAppPositionByUserId(sysUser.getUserId()); - ArdAppPositions.add(ardAppPosition); + if (StringUtils.isNotNull(ardAppPosition)) { + Map<String, Object> params = new HashMap<>(); + params.put("longitude", ardAppPosition.getLongitude()); + params.put("latitude", ardAppPosition.getLatitude()); + params.put("speed", ardAppPosition.getSpeed()); + params.put("bearing", ardAppPosition.getBearing()); + params.put("name", sysUser.getUserName()); + ardAppPosition.setParams(params); + ArdAppPositions.add(ardAppPosition); + } } return ArdAppPositions; } + //杩囨护鍦ㄧ嚎app鐢ㄦ埛 + public static List<ArdAppPosition> isOnlie(List<ArdAppPosition> data) { + List<ArdAppPosition> onlineList = new ArrayList<>(); + if (data.size() > 0) { + for (ArdAppPosition ardAppPosition : data) { + ISysUserService sysUserService = SpringUtils.getBean(ISysUserService.class); + SysUser sysUser = sysUserService.selectUserById(ardAppPosition.getUserId()); + if (StringUtils.isNotNull(sysUser)) { + if (StringUtils.isNotNull(sysUser.getAppOnlineState())) { + if (sysUser.getAppOnlineState().equals("1")) { + onlineList.add(ardAppPosition); + } + } + } + } + } + return onlineList; + } + + //鎺ユ敹澶勭悊鍣� + public static void messageHandler(String userId, String message) { + try { + Map<String, Object> map = JSONObject.parseObject(message, Map.class); + if (map.size() > 0) { + Boolean enabled = (Boolean) map.get("enabled"); + if (enabled == null) { + return; + } + if (enabled) { + //鍚姩鍏ㄥ眬鎺ㄩ�� + List<ArdAppPosition> newList = new ArrayList<>(AppPositionPushService.getAppPositionList()); + AppPositionPushService.dataMap.put(userId, newList); + if (!AppPositionPushService.userTimerMap.containsKey(userId)) { + Timer timer = AppPositionPushService.startTimerTask(userId, 3000); + AppPositionPushService.userTimerMap.put(userId, timer);//灏嗗畾鏃跺櫒鍏宠仈鐢ㄦ埛 + } + } else { + //鍋滄鍏ㄥ眬鎺ㄩ�� + if (AppPositionPushService.userTimerMap.containsKey(userId)) { + Timer timer = AppPositionPushService.userTimerMap.get(userId); + AppPositionPushService.stopTimerTask(timer); + AppPositionPushService.userTimerMap.remove(userId); + } + if (AppPositionPushService.tempUserTimerMap.containsKey(userId)) { + Timer temptimer = AppPositionPushService.tempUserTimerMap.get(userId); + AppPositionPushService.stopTimerTask(temptimer); + AppPositionPushService.tempUserTimerMap.remove(userId); + } + AppPositionPushService.dataMap.remove(userId); + AppPositionPushService.tempDataMap.remove(userId); + } + + Integer frequency = (Integer) map.get("frequency"); + String uId = (String) map.get("userId"); + if (frequency > 0) { + List<ArdAppPosition> List = AppPositionPushService.getAppPositionList().stream() + .filter(obj -> !obj.getUserId().equals(uId)) + .collect(Collectors.toList());//鍘婚櫎寮曞鍚庣殑list + AppPositionPushService.dataMap.put(userId, List); + + List<ArdAppPosition> tempList = AppPositionPushService.getAppPositionList().stream() + .filter(obj -> obj.getUserId().equals(uId)) + .collect(Collectors.toList());//鑾峰彇寮曞鐨刲ist + AppPositionPushService.tempDataMap.put(userId, tempList); + Timer timer = AppPositionPushService.startTempTimerTask(userId, frequency); + AppPositionPushService.tempUserTimerMap.put(userId, timer); + } else { + List<ArdAppPosition> newList = new ArrayList<>(AppPositionPushService.getAppPositionList()); + AppPositionPushService.dataMap.put(userId, newList); + Timer timer = AppPositionPushService.tempUserTimerMap.get(userId); + AppPositionPushService.stopTimerTask(timer); + AppPositionPushService.tempUserTimerMap.remove(userId); + AppPositionPushService.tempDataMap.remove(userId); + } + } + } catch (Exception ex) { + log.error(ex.getMessage()); + WebSocketUtils.sendMessage(userId, "app浣嶇疆鎺ㄩ�佽В鏋愭秷鎭��" + message + "銆戝紓甯�:" + ex.getMessage()); + } + } + + //鍋滄澶勭悊鍣� + public static void stopHandler(String userId) { + //鍋滄鍏ㄥ眬鎺ㄩ�� + if (AppPositionPushService.userTimerMap.containsKey(userId)) { + Timer timer = AppPositionPushService.userTimerMap.get(userId); + AppPositionPushService.stopTimerTask(timer); + AppPositionPushService.userTimerMap.remove(userId); + } + if (AppPositionPushService.tempUserTimerMap.containsKey(userId)) { + Timer temptimer = AppPositionPushService.tempUserTimerMap.get(userId); + AppPositionPushService.stopTimerTask(temptimer); + AppPositionPushService.tempUserTimerMap.remove(userId); + } + AppPositionPushService.dataMap.remove(userId); + AppPositionPushService.tempDataMap.remove(userId); + // AppPositionPush.stopLocationPushTask(session);//鏃ф柟娉� + } } -- Gitblit v1.9.3