websocket over spring4 и весенняя безопасность SockJS / info? t = - PullRequest
0 голосов
/ 29 октября 2018

Я пытаюсь использовать websocket через пружину для отправки и получения некоторых строк. Раньше я работал с примером через Google, но после того, как все сложилось вместе, я получил запрос на URL, который недоступен в моем запросе контроллера.

Поток / WebSocket / добавить / информация? Т = 1540813753999

Мой контроллер выглядит так:

 @Controller("webSocketController") @RequestMapping("/websocket")
 public class WebSocketController {

    @MessageMapping("/add" )
     @SendTo("/topic/showResult")
     public Result addNum(CalcInput input) throws Exception {
        Thread.sleep(2000);
         Result result = new Result(input.getNum1()+"+"+input.getNum2()+"="+(input.getNum1()+input.getNum2()));

         return result;
     }

    @RequestMapping("/start")
     public String start() {
        return "start";
    }    }

и

@Configuration
@EnableWebSocketMessageBroker
public class AppWebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {

    @Override
    public void configureMessageBroker(MessageBrokerRegistry config) {
        config.enableSimpleBroker("/topic");
        config.setApplicationDestinationPrefixes("/calcApp");
    }

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

}

Часть Javascript:

<s:url value="/flow/websocket/add" var="sockendpoint" htmlEscape="true" />
<s:url value="/flow/websocket/topic/showResult" var="showresult" htmlEscape="true" />
<s:url value="/flow/websocket/calcApp/add" var="calcApp" htmlEscape="true" />


<script type="text/javascript">
        var stompClient = null;

        function setConnected(connected) {
            document.getElementById('connect').disabled = connected;
            document.getElementById('disconnect').disabled = !connected;
            document.getElementById('calculationDiv').style.visibility = connected ? 'visible'
                    : 'hidden';
            document.getElementById('calResponse').innerHTML = '';
        }

        function connect() {
            var socket = new SockJS('${sockendpoint}');
            //var socket = new WebSocket('${sockendpoint}');
            stompClient = Stomp.over(socket);
            stompClient.connect({}, function(frame) {
                setConnected(true);
                console.log('Connected: ' + frame);
                stompClient.subscribe('${showresult}', function(calResult) {
                    showResult(JSON.parse(calResult.body).result);
                });
            }, function(error) {
                console.log(error);
            });
        }

        function disconnect() {
            stompClient.disconnect();
            setConnected(false);
            console.log("Disconnected");
        }

        function sendNum() {
            var num1 = document.getElementById('num1').value;
            var num2 = document.getElementById('num2').value;
            stompClient.send("${calcApp}", {}, JSON.stringify({
                'num1' : num1,
                'num2' : num2
            }));
        }

        function showResult(message) {
            var response = document.getElementById('calResponse');
            var p = document.createElement('p');
            p.style.wordWrap = 'break-word';
            p.appendChild(document.createTextNode(message));
            response.appendChild(p);
        }
    </script>

/ flow - основное отображение для пружины на диспетчере

Заранее спасибо

1 Ответ

0 голосов
/ 29 октября 2018

Конечная точка "info" автоматически добавляется SockJS , поскольку она является частью ее протокола.

Это совершенно нормально , и конечная точка используется клиентом для получения информации о функциях сервера.

Кроме того, AFAIK вы не можете избежать этого, поскольку он указан как часть протокола, поэтому является обязательным.

См. Документацию Spring . Ссылка ниже:

https://docs.spring.io/spring/docs/5.0.0.BUILD-SNAPSHOT/spring-framework-reference/html/websocket.html

Раздел 22.3.1 Обзор SockJS , который объясняет причину конечной точки.


РЕДАКТИРОВАТЬ: реальная проблема не была связана с конечной точкой "info", которая автоматически добавляется платформой.

Проблема заключается в том, что клиент вызывал конечную точку сервера STOMP по servlet / app / stompEndpoint в следующей строке: <s:url value="/flow/websocket/add" var="sockendpoint" htmlEscape="true" />

Конечная точка / add сервера stomp не является частью самого приложения, поскольку сервер может фактически содержать несколько приложений. Итак, правильный путь должен быть servlet / stompEndpoint.

<s:url value="/flow/add" var="sockendpoint" htmlEscape="true" />

Также, вы можете проверить следующий пример Hello World , который объясняет это более подробно: https://spring.io/guides/gs/messaging-stomp-websocket/

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...