上一篇文章中介绍过SpringBoot整合websocket技术
本文在此基础上,介绍下在WebSocketSession会话中如何获取到http会话信息~
获取http会话用途
未使用前后端分离开发方案下,在WebSocketSession中如果能拿到HttpSession会话信息,就可以根据会话中的属性值,做相应的业务逻辑处理,比如权限控制,用户身份识别,信息过滤等等
- SpringBoot版本 2.4.5
使用方式
- 修改registerWebSocketHandlers配置,增加HttpSessionHandshakeInterceptor拦截器,用于实现同步HttpSession会话中的属性信息
- 修改WebSocketHandler消息处理器,尝试打印WebSocketSession中的会话信息,来观察http会话信息是否已经同步过来~
3.添加设置http会话信息的Controller层映射方法
4.编写前端测试代码来设置HttpSession会话信息,以及连接websocket服务
完整代码参考:https://github.com/netbuffer/spring-boot-websocket-demo/blob/master/src/main/resources/public/websocket.html
<script src="/reconnecting-websocket.js"></script>
<script type="text/javascript">
var ws = new ReconnectingWebSocket("ws://localhost:17000/ws", null, {
debug: true,
automaticOpen: false,
reconnectInterval: 3000
});
ws.onopen = function () {
console.log("Connection open ...");
}
ws.onmessage = function (r) {
console.log("Received Message: " + r.data);
}
ws.onclose = function () {
console.log("Connection closed.");
}
function connect() {
ws.open();
}
function set_session() {
var key = prompt("请输入key");
var value = prompt("请输入value");
var formData = new FormData();
formData.append('key', key);
formData.append('value', value);
fetch("/http/session/set", {
body: formData,
method: 'POST'
})
.then(function (response) {
return response;
})
.then(function (response) {
console.log(`send msg success`);
alert("send success");
});
}
</script>
</head>
<body>
<div>
<button onclick="connect()">connect</button>
<button onclick="set_session()">set_session</button>
</div>
运行效果
启动SpringBoot工程,访问http://localhost:17000/websocket.html
点击set_session按钮来设置属性值aaa/bbb
设置HttpSession会话属性完成后,现在我们再点击connect按钮,来发起websocket会话,并观察控制台日志输出~
观察结果,可以看到WebSocketSession中已经拿到了HttpSession中的会话信息了
至此,完成了在WebSocketSession中获取HttpSession会话信息的能力整合~
完整测试工程参考:https://github.com/netbuffer/spring-boot-websocket-demo