MessageMapping Handler - 没有匹配的方法

时间:2015-08-11 11:08:04

标签: java spring websocket

我有一个带有@MessageMapping注释方法的Spring webservice @Controller类,如下所示:

@MessageMapping("/trade")
public void executeTrade(MarketOrderRequest trade, Principal principal) {
    trade.setUserID(principal.getName());
    logger.debug("Trade: " + trade);
    this.tradeService.executeTrade(trade);
}

我发送的JSON字符串消息使用与服务器方法接受的相同的MarketOrderRequest POJO构建。使用一些Key:Value对,它们被设置为null(但仍然存在)。

WebSocketConfig类配置了以下端点:

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

当我尝试使用此代码向此消息映射发送消息时:

MarketOrderRequest request =  new MarketOrderRequest();
//{set request variables..}
StompHeaders someHeaders = new StompHeaders();
someHeaders.putAll(sessionHeaders);
someHeaders.setDestination("/app/trade");
session.send(someHeaders, request);

带标题:

{Cookie=[JSESSIONID=8421F536B639126F84F12E655375D790; Path=/spring-websocket-portfolio/; HttpOnly], version=[1.2], heart-beat=[0,0], user-name=[fabrice], destination=[/app/trade]}

然后服务器打印出无法找到请求的方法:

Searching methods to handle SEND /app/trade session=397da625042343b4bac1c913b6d8ec22 application/json;charset=UTF-8 
payload={"uuid":null,"symbol":"EUR/USD","price":1.10182,"side":"1","qty":50000,"quoteID"...(truncated)
WebSocketAnnotationMethodMessageHandler[DEBUG] - No matching methods.

服务器代码已从此项目解除,并稍作修改以满足我的需求:link

我在AbstractSecurityWebSocketMessageBrokerConfigurer实现类中添加了一些基于角色的Web套接字安全性,如下所示:

@Override
protected void configureInbound(MessageSecurityMetadataSourceRegistry messages) {
    messages
            .nullDestMatcher().authenticated()
            .simpSubscribeDestMatchers("/user/queue/errors").permitAll()
            .simpDestMatchers("/app/**").hasAnyRole("roleA", "roleB", "roleC")
            //{some more subscribe dest matchers by role which are working}
}

这可能会影响WebSocketAnnotationMethodMessageHandler尝试映射请求吗?这几乎是我对配置所做的唯一改变。我的订阅映射工作正常。

对我来说,由于JSON或Principal参数,似乎找不到方法。我发送正确的对象类型,这可能是用户主体的问题?感谢

1 个答案:

答案 0 :(得分:2)

我的WebSocketConfig类出错了。

@componentscan注释包名错误。我将名称更新为正确的值(我的基本包的名称,例如“com.my.project”)。现在,在日志中部署期间,我可以看到控制器资源被映射到我的类中的方法。

例如,一种方法的日志输出:

  

将“{[/ order],messageType = [MESSAGE]}”映射到public void com.my.project.web.PortfolioController.executeOrder(tradeObjects.OrderRequest,java.security.Principal)