SpringBoot整合websocket获取http会话信息

上一篇文章中介绍过SpringBoot整合websocket技术

使用SpringBoot搭建实时通信服务

本文在此基础上,介绍下在WebSocketSession会话中如何获取到http会话信息~

获取http会话用途

未使用前后端分离开发方案下,在WebSocketSession中如果能拿到HttpSession会话信息,就可以根据会话中的属性值,做相应的业务逻辑处理,比如权限控制,用户身份识别,信息过滤等等

  • SpringBoot版本 2.4.5

使用方式

1.修改registerWebSocketHandlers配置,增加HttpSessionHandshakeInterceptor拦截器,用于实现同步HttpSession会话中的属性信息

2.修改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)


原网址: 访问
创建于: 2023-04-10 09:57:08
目录: default
标签: 无

请先后发表评论
  • 最新评论
  • 总共0条评论