J'essaie d'établir une connexion entre le client et le serveur via Spring webSocket et je le fais à l'aide de ce lien . Je veux que le contrôleur envoie un "bonjour" au client toutes les 5 secondes et le client l'ajoute à la boîte de voeux à chaque fois. Il s'agit de la classe de contrôleur:
@EnableScheduling
@Controller
public class GreetingController {
@Scheduled(fixedRate = 5000)
@MessageMapping("/hello")
@SendTo("/topic/greetings")
public Greeting greeting() throws Exception {
Thread.sleep(1000); // simulated delay
System.out.println("scheduled");
return new Greeting("Hello");
}
}
et c'est la fonction Connect () dans app.jsp:
function connect() {
var socket = new SockJS('/gs-guide-websocket');
stompClient = Stomp.over(socket);
stompClient.connect({}, function (frame) {
setConnected(true);
console.log('Connected: ' + frame);
stompClient.send("/app/hello", {}, JSON.stringify({'name': "connect"}));
stompClient.subscribe('/topic/greetings', function (message) {
console.log("message"+message);
console.log("message"+(JSON.parse(message.body)));
showGreeting(JSON.parse(message.body).content);
});
});
}
lorsque le fichier index.jsp se charge et que j'appuie sur le bouton de connexion, une seule fois il ajoute bonjour dans le message d'accueil, comment dois-je faire en sorte que le client affiche le message "bonjour" toutes les 5 secondes?
Veuillez vous référer à cette partie de la documentation . La façon dont vous essayez d'envoyer un message est totalement fausse. Je modifierais votre classe ci-dessus comme suit:
@EnableScheduling
@Controller
public class GreetingController {
@Autowired
private SimpMessagingTemplate template;
@Scheduled(fixedRate = 5000)
public void greeting() {
Thread.sleep(1000); // simulated delay
System.out.println("scheduled");
this.template.convertAndSend("/topic/greetings", "Hello");
}
}