feat():Socket

This commit is contained in:
Penknife
2025-01-10 08:59:54 +08:00
parent ff96a7ff2e
commit d2c7766624
6 changed files with 86 additions and 2 deletions

View File

@@ -12,6 +12,11 @@ public class RabbitConfig {
return new Queue(CommonConstants.RabbitMQ.RECEIVE_MODEL, true);
}
@Bean
public Queue receiveRealTimeQueue() {
return new Queue(CommonConstants.RabbitMQ.RECEIVE_REAL_TIME, true);
}
@Bean
public Queue sendModelQueue() {
return new Queue(CommonConstants.RabbitMQ.SEND_MODEL, true);

View File

@@ -0,0 +1,26 @@
package com.fizz.business.config;
import com.fizz.business.interceptor.TrackWsInterceptor;
import com.fizz.business.service.client.TrackWsHandler;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.socket.config.annotation.EnableWebSocket;
import org.springframework.web.socket.config.annotation.WebSocketConfigurer;
import org.springframework.web.socket.config.annotation.WebSocketHandlerRegistry;
@Configuration
@EnableWebSocket
public class WebSocketConfig implements WebSocketConfigurer {
@Autowired
TrackWsHandler trackWsHandler;
@Autowired
TrackWsInterceptor trackWsInterceptor;
@Override
public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) {
registry.addHandler(trackWsHandler, "/websocket")
.addInterceptors(trackWsInterceptor)
.setAllowedOrigins("*"); //允许跨域
}
}

View File

@@ -24,6 +24,8 @@ public class CommonConstants {
public class RabbitMQ {
public static final String RECEIVE_MODEL = "plateform.hmi.queue";
public static final String RECEIVE_REAL_TIME = "plateform.realtime.queue";
public static final String SEND_MODEL = "plateform.modpt.queue";
}

View File

@@ -0,0 +1,40 @@
package com.fizz.business.interceptor;
import com.fizz.business.constants.enums.WsTypeEnum;
import lombok.extern.slf4j.Slf4j;
import org.springframework.http.server.ServerHttpRequest;
import org.springframework.http.server.ServerHttpResponse;
import org.springframework.http.server.ServletServerHttpRequest;
import org.springframework.stereotype.Component;
import org.springframework.web.socket.WebSocketHandler;
import org.springframework.web.socket.server.HandshakeInterceptor;
import java.util.Map;
import java.util.Objects;
@Slf4j
@Component
public class TrackWsInterceptor implements HandshakeInterceptor {
@Override
public boolean beforeHandshake(ServerHttpRequest request, ServerHttpResponse response, WebSocketHandler wsHandler, Map<String, Object> attributes) throws Exception {
try {
String type = ((ServletServerHttpRequest) request).getServletRequest().getParameter("type");
if (Objects.isNull(WsTypeEnum.getByValue(type))) {
log.error("[websocket]beforeHandshake error: type={}", type);
return false;
}
attributes.put("type", type);
return true;
} catch (Exception e) {
log.error("[websocket]beforeHandshake error", e);
return false;
}
}
@Override
public void afterHandshake(ServerHttpRequest request, ServerHttpResponse response, WebSocketHandler wsHandler, Exception exception) {
}
}

View File

@@ -1,6 +1,7 @@
package com.fizz.business.mq.RabbitMQ;
import cn.hutool.json.JSONUtil;
import com.fizz.business.constants.CommonConstants;
import com.fizz.business.constants.enums.WsTypeEnum;
import com.fizz.business.utils.WebSocketUtil;
import lombok.extern.log4j.Log4j2;
@@ -9,9 +10,17 @@ import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;
@Log4j2
//@Component
@Component
public class RabbitQueueListener {
@RabbitListener(queues = "plateform.hmi.queue")
@RabbitListener(queues = CommonConstants.RabbitMQ.RECEIVE_MODEL)
@RabbitHandler
public void onHmiMessage(String message) {
log.info("消费端ProcData: " + message);
//socket
}
@RabbitListener(queues = CommonConstants.RabbitMQ.RECEIVE_REAL_TIME)
@RabbitHandler
public void onProcDataMessage(String message) {
log.info("消费端ProcData: " + message);