一.项目创建
二.代码
package com.miracle.websocket.config;
import com.miracle.websocket.handler.TextMessageHandler;
import com.miracle.websocket.interceptor.WebSocketInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.socket.config.annotation.EnableWebSocket;
import org.springframework.web.socket.config.annotation.WebSocketConfigurer;
import org.springframework.web.socket.config.annotation.WebSocketHandlerRegistry;
import org.springframework.web.socket.handler.TextWebSocketHandler;
@Configuration
@EnableWebSocket
public class WebSocketConfig implements WebSocketConfigurer {
@Override
public void registerWebSocketHandlers(WebSocketHandlerRegistry webSocketHandlerRegistry) {
webSocketHandlerRegistry.addHandler(socketHandler(), "/websocket/*").addInterceptors(new WebSocketInterceptor());
}
@Bean
public TextWebSocketHandler socketHandler(){
return new TextMessageHandler();
}
}
package com.miracle.websocket.interceptor;
import org.springframework.http.server.ServerHttpRequest;
import org.springframework.http.server.ServerHttpResponse;
import org.springframework.web.socket.WebSocketHandler;
import org.springframework.web.socket.server.support.HttpSessionHandshakeInterceptor;
import java.util.Map;
public class WebSocketInterceptor extends HttpSessionHandshakeInterceptor {
@Override
public boolean beforeHandshake(ServerHttpRequest request, ServerHttpResponse response, WebSocketHandler wsHandler, Map<String, Object> attributes) throws Exception {
String url = request.getURI().toString();
String name = url.substring(url.lastIndexOf("/") + 1);
attributes.put("name", name);
return super.beforeHandshake(request, response, wsHandler, attributes);
}
@Override
public void afterHandshake(ServerHttpRequest request, ServerHttpResponse response, WebSocketHandler wsHandler, Exception ex) {
}
}
package com.miracle.websocket.handler;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.web.socket.CloseStatus;
import org.springframework.web.socket.TextMessage;
import org.springframework.web.socket.WebSocketSession;
import org.springframework.web.socket.handler.TextWebSocketHandler;
import java.util.HashMap;
import java.util.Map;
public class TextMessageHandler extends TextWebSocketHandler {
private Map<String,WebSocketSession> allClient = new HashMap<>();
@Override
public void afterConnectionEstablished(WebSocketSession session) throws Exception {
String name = (String) session.getAttributes().get("name");
if (name != null){
allClient.put(name, session);
}
}
@Override
protected void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception {
ObjectMapper objectMapper = new ObjectMapper();
Map<String, String> jsonMap = objectMapper.readValue(new String(message.asBytes()), Map.class);
String toUser = jsonMap.get("toUser");
String toMessage = jsonMap.get("toMessage");
String fromUser = (String)session.getAttributes().get("name");
String content = "收到来自" + fromUser + "的消息,内容是:" + toMessage;
TextMessage textMessage = new TextMessage(content);
WebSocketSession toSession = allClient.get(toUser);
if (toMessage != null && session.isOpen()){
toSession.sendMessage(textMessage);
}
}
@Override
public void afterConnectionClosed(WebSocketSession session, CloseStatus status) throws Exception {
super.afterConnectionClosed(session, status);
}
}
<html>
<head>
<meta charset="UTF-8">
<script type="text/javascript">
var webSocket = null;
function connection() {
var username = document.getElementById("name").value;
if ('WebSocket' in window){
webSocket = new WebSocket("ws://" + document.location.host + "/websocket/" + username);
}else {
alert('不支持Websocket')
}
webSocket.onopen = function () {
document.getElementById("message").innerHTML = "建立连接了";
};
webSocket.onmessage = function (event) {
var data = event.data;
document.getElementById("message").innerHTML = "收到消息了:" + data;
};
webSocket.onerror = function () {
document.getElementById("message").innerHTML = "出现异常了";
};
webSocket.onclose = function () {
document.getElementById("message").innerHTML = "连接关闭了";
};
window.onbeforeunload = function (event) {
if (webSocket != null){
webSocket.close();
}
}
};
function sendMessage(){
var toUser = document.getElementById("toUser").value;
var toMessage = document.getElementById("toMessage").value;
if(webSocket != null){
var message = '{"toUser":"' + toUser + '","toMessage":"' + toMessage + '"}';
webSocket.send(message);
}
}
</script>
</head>
<body>
<input type="text" id="name" name="name">
<button onclick="connection()">连接</button>
<br>
接收者名字:<input type="text" name="toUser" id="toUser"><br>
内容:<input type="text" name="toMessage" id="toMessage"><br>
<button onclick="sendMessage()">发送</button>
<h2 id="message">Hello World!</h2>
</body>
</html>