ins*_*hex 2 spring stomp websocket kotlin
我正在尝试在 Spring Boot 应用程序中配置订阅映射以通过 websockets 进行踩踏,但没有任何运气。我相当确定我已经正确配置了 stomp/websocket 内容,因为我能够订阅 kafka 消费者发布的主题,但使用 @SubscribeMapping 根本不起作用。
这是我的控制器
@Controller
class TestController {
@SubscribeMapping("/topic/test")
fun testMapping(): String {
return "THIS IS A TEST"
}
}
Run Code Online (Sandbox Code Playgroud)
这是我的配置
@Configuration
@EnableWebSocketMessageBroker
@Order(Ordered.HIGHEST_PRECEDENCE + 99)
class WebSocketConfig : AbstractWebSocketMessageBrokerConfigurer() {
override fun configureMessageBroker(config: MessageBrokerRegistry) {
config.setApplicationDestinationPrefixes("/app", "/topic")
config.enableSimpleBroker("/queue", "/topic")
config.setUserDestinationPrefix("/user")
}
override fun registerStompEndpoints(registry:StompEndpointRegistry) {
registry.addEndpoint("/ws").setAllowedOrigins("*")
}
override fun configureClientInboundChannel(registration: ChannelRegistration?) {
registration?.setInterceptors(object: ChannelInterceptorAdapter() {
override fun preSend(message: Message<*>, channel: MessageChannel): Message<*> {
val accessor: StompHeaderAccessor = MessageHeaderAccessor.getAccessor(message, StompHeaderAccessor::class.java)
if (StompCommand.CONNECT.equals(accessor.command)) {
Optional.ofNullable(accessor.getNativeHeader("authorization")).ifPresent {
val token = it[0]
val keyReader = KeyReader()
val creds = Jwts.parser().setSigningKey(keyReader.key).parseClaimsJws(token).body
val groups = creds.get("groups", List::class.java)
val authorities = groups.map { SimpleGrantedAuthority(it as String) }
val authResult = UsernamePasswordAuthenticationToken(creds.subject, token, authorities)
SecurityContextHolder.getContext().authentication = authResult
accessor.user = authResult
}
}
return message
}
})
}
}
Run Code Online (Sandbox Code Playgroud)
然后在 UI 代码中,我使用 Angular 和 stompjs 包装器来订阅它,如下所示:
this.stompService.subscribe('/topic/test')
.map(data => data.body)
.subscribe(data => console.log(data));
Run Code Online (Sandbox Code Playgroud)
像这样订阅我知道正在发出数据的主题效果很好,但订阅映射什么也不做。我还尝试将事件侦听器添加到我的 websocket 配置中,以测试 UI 是否实际上向后端发送订阅事件,如下所示:
@EventListener
fun handleSubscribeEvent(event: SessionSubscribeEvent) {
println("Subscription event: $event")
}
@EventListener
fun handleConnectEvent(event: SessionConnectEvent) {
println("Connection event: $event")
}
@EventListener
fun handleDisconnectEvent(event: SessionDisconnectEvent) {
println("Disconnection event: $event")
}
Run Code Online (Sandbox Code Playgroud)
添加这些事件侦听器后,我可以看到我期望从 UI 发出的所有事件都在 kotlin 层中通过,但我的控制器方法从未被调用。我有什么明显遗漏的东西吗?
请尝试以下操作:
@Controller
class TestController {
@SubscribeMapping("/test")
fun testMapping(): String {
return "THIS IS A TEST"
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3890 次 |
| 最近记录: |