gpt4 book ai didi

spring - 在 Spring 中使用 STOMP 和 WebSocket 向特定用户发送消息时检查身份验证

转载 作者:行者123 更新时间:2023-12-04 04:48:15 34 4
gpt4 key购买 nike

我正在开发一个实时通知系统 Spring 4 通过使用内置 消息代理 , 和 跺脚 超过 WebSocket .

我希望能够根据他的用户名向特定用户发送消息。
为了实现这个目标,我使用了 convertAndSendToUser org.springframework.messaging.simp.SimpMessagingTemplate的方法类,如下:

private final MessagingTemplate messagingTemplate;

@Autowired
public LRTStatusListener(SimpMessagingTemplate messagingTemplate) {
this.messagingTemplate = messagingTemplate;
}


@Scheduled(fixedDelay=5000)
public void sendMessages(Principal principal)
messagingTemplate
.convertAndSendToUser(principal.getName(), "/horray", "Horray, " + principal.getName() + "!");
}

作为配置:
@Configuration
@EnableScheduling
@EnableWebSocketMessageBroker
public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {

@Override
public void registerStompEndpoints(StompEndpointRegistry registry) {
registry.addEndpoint("/notifications").withSockJS();
}

@Override
public void configureMessageBroker(MessageBrokerRegistry registry) {
registry.enableSimpleBroker("/topic", "/queue", "/user");
}

}

客户端(通过 JavaScript ),我应该通过指定用户名来订阅 channel (根据另一个非常相似的问题: Sending message to specific user on Spring Websocket )。
stompClient.subscribe('/user/' + username + '/horray, ...) 

最后一点听起来很奇怪......

假设我在我的 webapp 上登录为 w.white,通过订阅:
stompClient.subscribe('/user/w.white/horray, ...)

...我将能够看到发送到 w.white 的消息,这太棒了...但是订阅:
stompClient.subscribe('/user/j.pinkman/horray, ...)

...我也将能够看到发送到 j.pinkman 的消息,尽管我目前登录为 w.white。

这是一种克服这个问题的方法吗?

更新

下面是关于通过 WebSocket 进行连接的日志:
Opening Web Socket... 
Web Socket Opened...
>>> CONNECT
accept-version:1.1,1.0
heart-beat:10000,10000

<<< CONNECTED
user-name:w.white
heart-beat:0,0
version:1.1

connected to server undefined
Connected: CONNECTED
version:1.1
heart-beat:0,0
user-name:w.white

>>> SUBSCRIBE
id:sub-0
destination:/topic/lrt

>>> SUBSCRIBE
id:sub-1
destination:/user/lrt

最佳答案

我找到了解决方案。

首先,重要的是要知道 /user channel 已由 管理 Spring STOMP ,顺便说一句,不需要注册。

所以:

@Override
public void configureMessageBroker(MessageBrokerRegistry registry) {
registry.enableSimpleBroker("/topic", "/queue");
}

然后,我将目标 channel 设置为 /queue/horray :
@Scheduled(fixedDelay=5000)
public void sendMessages(Principal principal)
messagingTemplate
.convertAndSendToUser(principal.getName(), "/queue/horray", "Horray, " + principal.getName() + "!");
}

最后,在客户端:
stompClient.subscribe('/user/queue/horray', '...');

现在,它工作正常!根据 Principal,消息只发送给指定的收件人。由安全上下文获取。

关于spring - 在 Spring 中使用 STOMP 和 WebSocket 向特定用户发送消息时检查身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25646671/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com