spring websocket 调用受权限保护的方法失败

版本

spring-security 5.6.10

spring-websocket 5.3.27

现象

通过AbstractWebSocketHandler实现websocket端点处理器

调用使用@PreAuthorize注解的方法报错,无法在SecurityContext中找到认证信息

org.springframework.security.authentication.AuthenticationCredentialsNotFoundException

An Authentication object was not found in the SecurityContext

原因

调用websockethandler的线程非用户会话线程,所以安全上下文中没有认证信息

解决

在处理消息时将WebsocketSession中保存的认证信息设置到SecurityContext中

java 复制代码
import org.springframework.web.socket.handler.AbstractWebSocketHandler;
public class MyWsHandler extends AbstractWebSocketHandler {
	public void handleMessage(WebSocketSession session, WebSocketMessage<?> message) throws Exception {
		// 在安全上下文中设置认证信息
        SecurityContextHolder.getContext().setAuthentication((Authentication)session.getPrincipal());
        super.handleMessage(session, message);
    }
    protected void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception {
        // 调用受保护的方法
        this.service.doSomething();
    }
}
相关推荐
证能量少女21 分钟前
2026大专Java开发工程师,考什么证加分?
java·开发语言
FPGAI21 分钟前
Java学习之基础概念
java·学习
芒克芒克23 分钟前
Java集合框架总结(面试八股)
java·开发语言·面试
ejjdhdjdjdjdjjsl1 小时前
C#文件流操作技巧
java·开发语言·spring
虾说羊1 小时前
HashMap详解
java
lkbhua莱克瓦241 小时前
反射3-反射获取构造方法
java·开发语言·反射
wanghowie1 小时前
02.04.01 Java Stream API 进阶指南:从底层实现到性能优化
java·开发语言·性能优化
专注于大数据技术栈1 小时前
java学习--Date
java·学习
青莲8431 小时前
Java基础篇——第三部
java·前端