| | |
| | | import com.whyc.factory.ThreadPoolExecutorFactory; |
| | | import com.whyc.pojo.Battinf; |
| | | import com.whyc.pojo.PowerInf; |
| | | import com.whyc.service.BadBattMonService; |
| | | import com.whyc.service.BattInfService; |
| | | import com.whyc.service.BatttestdataInfService; |
| | | import com.whyc.service.PowerInfService; |
| | | import com.whyc.pojo.StationInf; |
| | | import com.whyc.pojo.UserInf; |
| | | import com.whyc.service.*; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Component; |
| | | |
| | | import javax.servlet.http.HttpSession; |
| | | import javax.websocket.*; |
| | | import javax.websocket.server.ServerEndpoint; |
| | | import java.io.IOException; |
| | | import java.util.HashMap; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | |
| | | import java.util.stream.Collectors; |
| | | |
| | | /** |
| | | * 总首页 |
| | | * 总首页(领导层) |
| | | */ |
| | | @Component |
| | | @ServerEndpoint(value = "/homeAdmin", encoders = WebSocketEncoder.class, configurator = WebSocketConfig.class) |
| | |
| | | |
| | | private Thread thread; |
| | | |
| | | private volatile boolean runFlag = true; |
| | | |
| | | private volatile Map<String, Thread> threadMap = new HashMap<>(); |
| | | |
| | | private volatile Map<Long, Boolean> threadFlagMap = new HashMap<>(); |
| | | |
| | | private static final int executeTime = 5000; |
| | | |
| | | private static BattInfService battInfService; |
| | | |
| | | private static StationInfService stationInfService; |
| | | |
| | | private static BadBattMonService badBattMonService; |
| | | |
| | |
| | | private static PowerInfService powerInfService; |
| | | |
| | | private static BatttestdataInfService batttestdataInfService; |
| | | |
| | | private HttpSession httpSession; |
| | | |
| | | @Autowired |
| | | public void setBattInfService(BattInfService battInfService) { |
| | |
| | | HomeAdminSocket.batttestdataInfService = batttestdataInfService; |
| | | } |
| | | |
| | | @Autowired |
| | | public void setStationInfService(StationInfService stationInfService) { |
| | | HomeAdminSocket.stationInfService = stationInfService; |
| | | } |
| | | |
| | | @OnOpen |
| | | public void onOpen(Session session, EndpointConfig config) { |
| | | this.session = session; |
| | | /*HttpSession httpSession = (HttpSession) config.getUserProperties().get("httpSession"); |
| | | UserInf user = (UserInf) httpSession.getAttribute("user"); |
| | | final int userId = user.getUId().intValue();*/ |
| | | final int userId = 1001; |
| | | this.httpSession = (HttpSession) config.getUserProperties().get("httpSession"); |
| | | } |
| | | |
| | | @OnMessage |
| | | public void onMessage(Session session, String message) { |
| | | UserInf user = (UserInf) this.httpSession.getAttribute("user"); |
| | | final int userId = user.getUId().intValue(); |
| | | //final int userId = 1087; |
| | | Thread thread = new Thread() { |
| | | @Override |
| | | public void run() { |
| | |
| | | ThreadPoolExecutor poolExecutor = ThreadPoolExecutorFactory.getPoolExecutor(); |
| | | CountDownLatch latch = new CountDownLatch(7); |
| | | poolExecutor.execute(() -> { |
| | | //蓄电池优劣分析 |
| | | Response resQualityAnalysis = badBattMonService.getQualityAnalysis(userId); |
| | | res.put("resQualityAnalysis", resQualityAnalysis); |
| | | Response resGroupAnalysis = batttestdataInfService.getGroupAnalysis3(userId); |
| | | res.put("resGroupAnalysis", resGroupAnalysis); |
| | | latch.countDown(); |
| | | }); |
| | | poolExecutor.execute(() -> { |
| | |
| | | //站点信息 |
| | | Response resStationAnalysis = new Response(); |
| | | try { |
| | | List<Battinf> battinfList = battInfService.getSateAnalysis(userId); |
| | | Map<Integer, List<Battinf>> nodeStationMap = battinfList.stream().collect(Collectors.groupingBy(Battinf::getNodeStation)); |
| | | Map<String, List<Battinf>> stationTypeMap = battinfList.stream().collect(Collectors.groupingBy(Battinf::getStationType)); |
| | | //List<Battinf> battinfList = battInfService.getSateAnalysis(userId); |
| | | List<StationInf> sinfList = stationInfService.getSateAnalysis(userId); |
| | | Map<Integer, List<StationInf>> nodeStationMap = sinfList.stream().collect(Collectors.groupingBy(StationInf::getNodeStation)); |
| | | Map<String, List<StationInf>> stationTypeMap = sinfList.stream().collect(Collectors.groupingBy(StationInf::getStationType)); |
| | | Map<Integer, Object> nodeMap = new HashMap<>(); |
| | | Map<String, Object> stationMap = new HashMap<>(); |
| | | Map<String, Object> battGroupInfoMap = new HashMap<>(); |
| | | int battSize = battinfList.size(); |
| | | int battSize = sinfList.size(); |
| | | for (Integer node : nodeStationMap.keySet()) { |
| | | nodeMap.put(node, nodeStationMap.get(node).size()); |
| | | } |
| | |
| | | }); |
| | | latch.await(10, TimeUnit.MINUTES); |
| | | session.getBasicRemote().sendObject(new Response().set(1, res)); |
| | | sleep(4000); |
| | | sleep(5000); |
| | | } |
| | | } catch (Exception e) { |
| | | this.interrupt(); |
| | |
| | | } |
| | | |
| | | @OnClose |
| | | public void onClose(CloseReason closeReason) throws IOException { |
| | | //System.err.println("closeReason = " + closeReason); |
| | | if (session.isOpen()) { |
| | | session.close(); |
| | | public void onClose(CloseReason closeReason) { |
| | | System.err.println("closeReason = " + closeReason); |
| | | runFlag = false; |
| | | if (thread != null && thread.isAlive()) { |
| | | thread.interrupt(); |
| | | } |
| | | threadMap.remove(session.getId()); |
| | | } |
| | | |
| | | @OnError |
| | | public void onError(Throwable error) throws IOException { |
| | | //error.printStackTrace(); |
| | | thread.isInterrupted(); |
| | | if (session.isOpen()) { |
| | | session.close(); |
| | | public void onError(Throwable error) { |
| | | error.printStackTrace(); |
| | | if (thread != null && thread.isAlive()) { |
| | | thread.interrupt(); |
| | | } |
| | | threadMap.remove(session.getId()); |
| | | } |
| | | |
| | | } |