spring websocket stomp如何向服务端传递参数

之前的这篇文章,html页面和java代码是写死的只能向greetings这个主题发送信息,很显然有很大的局限性,现在我们看下如何传递参数。html页面中通过stomp给服务端传递参数有2种方式:在消息头中添加参数,在路径中添加参数。


方式1:在消息头中添加参数

function sendName() {
            var name = document.getElementById('name').value;
            stompClient.send("/app/hello", {atytopic:"greetings"}, name);
        }


对应的java代码可以通过如下方式来接收参数:使用@Header或者@Headers

@Controller
public class ChatController {

	@Autowired
	private SimpMessagingTemplate template;

	@MessageMapping("/hello")
	public String send(String message, @Header("atytopic") String topic,
			@Headers Map<String, Object> headers) {

		System.out.println("message==" + message);
		System.out.println("topic==" + topic);
		System.out.println("headers==" + headers);

		template.convertAndSend("/topic/" + topic, message);

		return "";
	}

}


方式2:在路径中添加参数,这个类似于rest服务在url中写参数。

function sendName() {
            var name = document.getElementById('name').value;
            stompClient.send("/app/hello/aty/greetings", {}, name);
        }


后台java代码如下:使用@DestinationVariable接收

@Controller
public class Chat2Controller {

	@Autowired
	private SimpMessagingTemplate template;

	// 如果只有一个模板变量,那么可以直接使用@DestinationVariable
	@MessageMapping("/hello/{userName}/{topic}")
	public String send(String message, @DestinationVariable("topic") String topic, @DestinationVariable(value="userName") String userName) {

		System.out.println("message=="+message);
		System.out.println("topic=="+topic);
		System.out.println("userName=="+userName);
		
		template.convertAndSend("/topic/"+topic, message);

		return "";
	}

	
}


可以看到这2种方式都可以正确传递参数到服务端。


  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Stomp WebSocket是一种基于WebSocket协议的通信方式,它使用Stomp协议在客户端和服务器之间进行消息传递。Stomp是一个简单的文本协议,支持基于消息的中间件通信。 Spring提供了对Stomp WebSocket的支持,可以轻松地创建基于StompWebSocket应用程序。在Spring中,可以使用Spring WebSocket模块和Spring Messaging模块来实现Stomp WebSocket。 首先需要在pom.xml文件中添加相关依赖: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency> <dependency> <groupId>org.springframework.messaging</groupId> <artifactId>spring-messaging</artifactId> </dependency> ``` 然后,需要创建一个WebSocket配置类,该类需要继承WebSocketMessageBrokerConfigurer接口,并实现其方法,如下所示: ``` @Configuration @EnableWebSocketMessageBroker public class WebSocketConfig implements WebSocketMessageBrokerConfigurer { @Override public void configureMessageBroker(MessageBrokerRegistry config) { config.enableSimpleBroker("/topic"); config.setApplicationDestinationPrefixes("/app"); } @Override public void registerStompEndpoints(StompEndpointRegistry registry) { registry.addEndpoint("/ws").withSockJS(); } } ``` 在这个配置类中,我们首先通过@EnableWebSocketMessageBroker注解启用了WebSocket消息代理,并实现了configureMessageBroker()方法来配置消息代理。这里我们使用了一个简单的消息代理来处理消息,使用/topic作为消息前缀,使用/app作为应用程序前缀。 接下来,我们使用registerStompEndpoints()方法注册了一个Stomp协议的WebSocket端点,客户端可以使用这个端点来连接WebSocket服务器。这里我们使用了withSockJS()方法来启用SockJS支持,以便在WebSocket不可用时提供备用传输。 最后,我们需要创建一个控制器类来处理WebSocket请求,如下所示: ``` @Controller public class WebSocketController { @MessageMapping("/hello") @SendTo("/topic/greetings") public Greeting greeting(HelloMessage message) throws Exception { Thread.sleep(1000); // simulated delay return new Greeting("Hello, " + message.getName() + "!"); } } ``` 在这个控制器类中,我们使用@MessageMapping注解来处理客户端发送的消息,使用@SendTo注解将消息发送到指定的目的地。在这个例子中,我们使用了“/hello”作为目的地,所以客户端发送的消息需要以“/app/hello”格式发送。而我们使用了“/topic/greetings”作为发送目的地,所以服务端返回的消息将会被发送到“/topic/greetings”这个主题中,所有订阅这个主题的客户端都将收到这条消息。 以上就是Spring Stomp WebSocket的简单介绍和使用方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值