【发布时间】:2014-10-27 18:00:55
【问题描述】:
Spring Security 是一个非常好的框架,广泛用于身份验证和授权。
我有一个要求,应用程序要使用 j_spring_security_check 进行身份验证,并且只有授权用户才能向 websocket 处理程序发出请求。
我已经按照http://malalanayake.wordpress.com/2014/06/27/spring-security-on-rest-api/配置了spring security
我已经按照http://syntx.io/using-websockets-in-java-using-spring-4/配置了websocket。
我希望从 handleTextMessage 处理程序访问 MyPrincipal 主体对象,如下所示:
@Override
protected void handleTextMessage(WebSocketSession session,
TextMessage message) throws Exception {
System.out.println("Protocol: "+session.getAcceptedProtocol());
TextMessage returnMessage = new TextMessage(message.getPayload()
+ " received at server");
System.out.println("myAttrib="
+ session.getAttributes().get("myAttrib"));
MyPrincipal user = (MyPrincipal) ((Authentication) session
.getPrincipal()).getPrincipal();
System.out.println("User: " + user.getUserId());
session.sendMessage(returnMessage);
}
请尽快重播。
【问题讨论】:
标签: java spring spring-security websocket