From a99354841669e8d4c4ef76428348b1a5ef1db065 Mon Sep 17 00:00:00 2001
From: guoshilong <123456>
Date: Wed, 22 Mar 2023 16:06:19 +0800
Subject: [PATCH] 模块不绑定设备,设备绑定模块。
---
src/main/java/org/springblade/common/handler/SocketIOService.java | 131 ++++++++++++-------------------------------
1 files changed, 37 insertions(+), 94 deletions(-)
diff --git a/src/main/java/org/springblade/common/handler/SocketIOService.java b/src/main/java/org/springblade/common/handler/SocketIOService.java
index 5163d35..d7f8d81 100644
--- a/src/main/java/org/springblade/common/handler/SocketIOService.java
+++ b/src/main/java/org/springblade/common/handler/SocketIOService.java
@@ -9,6 +9,7 @@
import com.corundumstudio.socketio.protocol.Packet;
import org.springblade.core.mp.support.Condition;
import org.springblade.core.tool.api.R;
+import org.springblade.core.tool.utils.StringUtil;
import org.springblade.modules.modules.entity.FunctionEntity;
import org.springblade.modules.modules.entity.ModulesEntity;
import org.springblade.modules.modules.service.IFunctionService;
@@ -28,6 +29,7 @@
import javax.annotation.PreDestroy;
import java.net.ServerSocket;
import java.util.ArrayList;
+import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
@@ -43,31 +45,13 @@
private final Logger log = LoggerFactory.getLogger(this.getClass());
- // 用来存已连接的客户端
- private static Map<String, SocketIOClient> viewMap = new ConcurrentHashMap<>();
-
- // 用来存已连接的客户端
- private static Map<String, SocketIOClient> controllerMap = new ConcurrentHashMap<>();
-
-// // 用来存已连接的视图客户端
-// private List<Map<String, SocketIOClient>> view = new ArrayList<>();
-//
-// // 用来存已连接的控制客户端
-// private List<Map<String, SocketIOClient>> controller = new ArrayList<>();
+ private static Map<String, SocketIOClient> clientMap = new ConcurrentHashMap<>();
@Autowired
private SocketIOServer socketIOServer;
- @Autowired
- private IFunctionService functionService;
-
- @Autowired
- private IModulesService modulesService;
-
/**
* Spring IoC容器创建之后,在加载SocketIOConfiguration Bean之后启动
- *
- * @throws Exception
*/
@PostConstruct
private void autoStartup() throws Exception {
@@ -76,8 +60,6 @@
/**
* Spring IoC容器在销毁SocketIOConfiguration Bean之前关闭,避免重启项目服务端口占用问题
- *
- * @throws Exception
*/
@PreDestroy
private void autoStop() throws Exception {
@@ -91,43 +73,19 @@
/**
* 连接时
- *
- * @param client
*/
@OnConnect
public void onConnect(SocketIOClient client) {
- FunctionVO functionEntity = getFuncVo(client);
+ String connectInfo = client.getHandshakeData().getSingleUrlParam("connectInfo");
+ SocketEntity socketEntity = parseMsg(connectInfo);
- //判断页面和控制器是否已经连接过了
- if (functionEntity.getIsView()) {
- for (int i = 0; i < viewMap.size(); i++) {
- if (viewMap.containsKey(functionEntity.getModulesId())) {
- client.sendEvent("connectError", R.fail("已连接"));
- return;
- }
- }
- } else {
- for (int i = 0; i < controllerMap.size(); i++) {
- if (controllerMap.containsKey(functionEntity.getModulesId())) {
- client.sendEvent("connectError", R.fail("已连接"));
- return;
- }
- }
- }
-
- List<FunctionEntity> all = functionService.getAll(functionEntity);
- if (all.size() > 0) {
- if (functionEntity.getIsView()) {
- log.info("预览页{}", client.getSessionId().toString());
- viewMap.put(functionEntity.getModulesId(), client);
-
- } else {
- log.info("控制页{}", client.getSessionId().toString());
- controllerMap.put(functionEntity.getModulesId(), client);
- }
- client.sendEvent("connectOk", R.data(all));
- } else {
- client.sendEvent("connectError", R.fail("连接失败"));
+ if (clientMap.containsKey(socketEntity.getCurrent())){
+ client.sendEvent("connectError",R.fail("连接已存在"));
+ log.info("设备{}连接已存在",socketEntity.getCurrent());
+ }else {
+ clientMap.put(socketEntity.getCurrent(),client);
+ client.sendEvent("connectOk",R.success("连接成功"));
+ log.info("设备{}连接成功",socketEntity.getCurrent());
}
}
@@ -149,20 +107,14 @@
@OnEvent(value = "changeImgPage")
public void OnEventImgChange(SocketIOClient client, AckRequest ackRequest, String data) {
log.info("图册变更:" + data);
- FunctionVO funcVo = getFuncVo(client);
-
-
- viewMap.forEach((e,socketIO)->{
- if (data.equals("previous")){
- if (e.equals(funcVo.getModulesId())){
- socketIO.sendEvent("previousPage","previous");
- }
- }else if (data.equals("next")){
- if (e.equals(funcVo.getModulesId())){
- socketIO.sendEvent("nextPage","next");
- }
- }
- });
+ SocketEntity socketEntity = parseMsg(data);
+ if (socketEntity.getMsg().equals("previous")) {
+ //上一页
+ clientMap.get(socketEntity.getTarget()).sendEvent("previousPage", "previous");
+ } else {
+ //下一页
+ clientMap.get(socketEntity.getTarget()).sendEvent("nextPage", "next");
+ }
}
/**
@@ -171,13 +123,9 @@
@OnEvent(value = "menuChange")
public void OnEventMenuChange(SocketIOClient client, AckRequest ackRequest, String data) {
log.info("菜单变更:" + data);
- FunctionVO funcVo = getFuncVo(client);
- viewMap.forEach((e,socketIOClient)->{
- if (e.equals(funcVo.getModulesId())){
- log.info("目标客户端:{}", socketIOClient.getSessionId().toString());
- socketIOClient.sendEvent("menuChange", data);
- }
- });
+ SocketEntity socketEntity = parseMsg(data);
+ log.info("控制的设备是:{}", parseMsg(client.getHandshakeData().getSingleUrlParam("connectInfo")).getTarget());
+ clientMap.get(socketEntity.getTarget()).sendEvent("menuChange", socketEntity.getMsg());
}
/**
@@ -187,22 +135,15 @@
*/
@OnDisconnect()
public void OnEvent(SocketIOClient client) {
- FunctionVO funcVo = getFuncVo(client);
- if (funcVo.getIsView()) {
- viewMap.forEach((e,socketIOClient)->{
- if (e.equals(funcVo.getModulesId())){
- viewMap.remove(e);
- log.info("预览页:{}断开连接", socketIOClient.getSessionId());
- }
- });
- } else {
- controllerMap.forEach((e,socketIOClient)->{
- if (e.equals(funcVo.getModulesId())){
- controllerMap.remove(e);
- log.info("控制页:{}断开连接", socketIOClient.getSessionId());
- }
- });
- }
+ String connectInfo = client.getHandshakeData().getSingleUrlParam("connectInfo");
+ SocketEntity socketEntity = parseMsg(connectInfo);
+ //保证断连只会断连自己,不会断连其他客户端
+ clientMap.forEach((key,value)->{
+ if (value.getSessionId().equals(client.getSessionId())){
+ clientMap.remove(key);
+ }
+ });
+ log.info("设备{}断开连接",socketEntity.getCurrent());
}
public void stop() {
@@ -240,9 +181,11 @@
return sa.substring(1, sa.indexOf(":"));
}
- private FunctionVO getFuncVo(SocketIOClient client) {
- String connectInfo = client.getHandshakeData().getSingleUrlParam("connectInfo");
- return JSON.parseObject(connectInfo, FunctionVO.class);
+ /**
+ * 解析参数,转化为实体类
+ */
+ private SocketEntity parseMsg(String msg) {
+ return JSON.parseObject(msg, SocketEntity.class);
}
--
Gitblit v1.9.3