È possibile utilizzare stomp su sockjs senza MVC. Quindi mi piacerebbe avere l'interfaccia a molla in tomcat, e l'applicazione angular2 eseguita da express.spring boot rest e angular2 con websocket (stomp over sockjs)
WebSocketConfig.java
@Configuration
@EnableWebSocketMessageBroker
public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {
@Override
public void registerStompEndpoints(StompEndpointRegistry registry) {
// the endpoint for websocket connections
registry.addEndpoint("/portfolio").setAllowedOrigins("*").withSockJS();
}
@Override
public void configureMessageBroker(MessageBrokerRegistry config) {
config.setApplicationDestinationPrefixes("/app");
config.enableSimpleBroker("/topic");
}
}
SocketController.java
@Controller
public class SocketController {
@Autowired
private SimpMessagingTemplate template;
public SocketController() {
int a = 5;
}
@MessageMapping("/greeting")
public String handle(String greeting) {
return "[" + "greeting" + ": " + greeting;
}
}
e il codice dattiloscritto:
. . .
constructor() {
var socket = new SockJS('http://localhost:8080/portfolio');
this.stompClient = Stomp.over(socket);
this.stompClient.connect("guest", "guest", function(frame) {
console.log('Connected: ' + frame);
this.stompClient.subscribe('http://localhost:8080/topic/greeting', function(greeting) {
console.log("from from", greeting);
});
}, function (err) {
console.log('err', err);
});
}
. . .
send() {
this.stompClient.send("http://localhost:8080/app/greeting", {}, JSON.stringify({ 'name': "kitica" }));
}
. . .
ma per qualche motivo questo non funziona .. in consolle ottengo uscita:
Opening Web Socket...
stomp.js:134 Web Socket Opened...
stomp.js:134 >>> CONNECT
login:guest
passcode:guest
accept-version:1.1,1.0
heart-beat:10000,10000
stomp.js:134 <<< CONNECTED
version:1.1
heart-beat:0,0
stomp.js:134 connected to server undefined
activity-socket.ts:17 Connected: CONNECTED
heart-beat:0,0
version:1.1
e quando invio ricevo
>>> SEND
destination:http://localhost:8080/app/greeting
content-length:17
{ "name": "kitica"}
ma il messaggio non ritorna mai all'abbonato.
angular2 è sulla porta 8001 e di riposo la primavera è il 8080
Se è possibile utilizzarlo in JS, è possibile utilizzarlo in Angular2. –
Ho una domanda aggiornata con un esempio di codice che ho provato, questo è secondo la loro documentazione –
Come hai aggiunto sockJS alla tua app angular2 per favore? –