Search code examples
javawebsocketstompspring-websocketsockjs

Print json array incoming from Stomp over Websocket controller


I added to my classpath jackson databind..

This is my java code (serverside)

       @MessageMapping("/hello")
        @SendTo("/topic/whoIsOnline")
        public List<User> greeting(String name) throws Exception {
            List<User> list = new ArrayList<User>();
            User user = new User();
            user.setEmail("test@gmail.com");
            list.add(user);
            User user1 = new User();
            user1.setEmail("example@gmail.com");
            list.add(user1);
            System.out.println(list);
            return list;
        }

This is JS code..

var stompClient = null;
    $(document).ready(function() {

        var socket = new SockJS('onlineUsers');
        stompClient = Stomp.over(socket);
        stompClient.connect({}, function(frame) {

            console.log('Connected: ' + frame);
            stompClient.subscribe('/topic/whoIsOnline', function(result) {
                var results = result.body;
                for(var i in results){
                      console.log(results[i].email);
                    }

            });
        });
    });

    function sendName() {
        var txtUser = $('#txtUser').val();
        stompClient.send("/app/hello", {}, JSON.stringify(txtUser));
    }

When I write document.writeln(results) it's printing like this...

[{"email":"test@gmail.com"},{"email":"example@gmail.com"}]

But , I want to print it like this..

test@gmail.com
example@gmail.com

for loop not work..

for(var i in results)
   {
      console.log(results[i].email);
   }

Solution

  • Try following code

    var results = result.body;
    var data = JSON.parse(results);
    for(var i in data){
        console.log(data[i].email);
    }