All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.springframework.web.socket.server.support.HttpSessionHandshakeInterceptor Maven / Gradle / Ivy

There is a newer version: 6.1.6
Show newest version
/*
 * Copyright 2002-2021 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.springframework.web.socket.server.support;

import java.util.Collection;
import java.util.Collections;
import java.util.Enumeration;
import java.util.Map;

import jakarta.servlet.http.HttpSession;

import org.springframework.http.server.ServerHttpRequest;
import org.springframework.http.server.ServerHttpResponse;
import org.springframework.http.server.ServletServerHttpRequest;
import org.springframework.lang.Nullable;
import org.springframework.web.socket.WebSocketHandler;
import org.springframework.web.socket.WebSocketSession;
import org.springframework.web.socket.server.HandshakeInterceptor;

/**
 * An interceptor to copy information from the HTTP session to the "handshake
 * attributes" map to be made available via {@link WebSocketSession#getAttributes()}.
 *
 * 

Copies a subset or all HTTP session attributes and/or the HTTP session ID * under the key {@link #HTTP_SESSION_ID_ATTR_NAME}. * * @author Rossen Stoyanchev * @since 4.0 */ public class HttpSessionHandshakeInterceptor implements HandshakeInterceptor { /** * The name of the attribute under which the HTTP session id is exposed when * {@link #setCopyHttpSessionId(boolean) copyHttpSessionId} is "true". */ public static final String HTTP_SESSION_ID_ATTR_NAME = "HTTP.SESSION.ID"; private final Collection attributeNames; private boolean copyAllAttributes; private boolean copyHttpSessionId = true; private boolean createSession; /** * Default constructor for copying all HTTP session attributes and the HTTP * session id. * @see #setCopyAllAttributes * @see #setCopyHttpSessionId */ public HttpSessionHandshakeInterceptor() { this.attributeNames = Collections.emptyList(); this.copyAllAttributes = true; } /** * Constructor for copying specific HTTP session attributes and the HTTP * session id. * @param attributeNames session attributes to copy * @see #setCopyAllAttributes * @see #setCopyHttpSessionId */ public HttpSessionHandshakeInterceptor(Collection attributeNames) { this.attributeNames = Collections.unmodifiableCollection(attributeNames); this.copyAllAttributes = false; } /** * Return the configured attribute names to copy (read-only). */ public Collection getAttributeNames() { return this.attributeNames; } /** * Whether to copy all attributes from the HTTP session. If set to "true", * any explicitly configured attribute names are ignored. *

By default this is set to either "true" or "false" depending on which * constructor was used (default or with attribute names respectively). * @param copyAllAttributes whether to copy all attributes */ public void setCopyAllAttributes(boolean copyAllAttributes) { this.copyAllAttributes = copyAllAttributes; } /** * Whether to copy all HTTP session attributes. */ public boolean isCopyAllAttributes() { return this.copyAllAttributes; } /** * Whether the HTTP session id should be copied to the handshake attributes * under the key {@link #HTTP_SESSION_ID_ATTR_NAME}. *

By default this is "true". * @param copyHttpSessionId whether to copy the HTTP session id. */ public void setCopyHttpSessionId(boolean copyHttpSessionId) { this.copyHttpSessionId = copyHttpSessionId; } /** * Whether to copy the HTTP session id to the handshake attributes. */ public boolean isCopyHttpSessionId() { return this.copyHttpSessionId; } /** * Whether to allow the HTTP session to be created while accessing it. *

By default set to {@code false}. * @see jakarta.servlet.http.HttpServletRequest#getSession(boolean) */ public void setCreateSession(boolean createSession) { this.createSession = createSession; } /** * Whether the HTTP session is allowed to be created. */ public boolean isCreateSession() { return this.createSession; } @Override public boolean beforeHandshake(ServerHttpRequest request, ServerHttpResponse response, WebSocketHandler wsHandler, Map attributes) throws Exception { HttpSession session = getSession(request); if (session != null) { if (isCopyHttpSessionId()) { attributes.put(HTTP_SESSION_ID_ATTR_NAME, session.getId()); } Enumeration names = session.getAttributeNames(); while (names.hasMoreElements()) { String name = names.nextElement(); if (isCopyAllAttributes() || getAttributeNames().contains(name)) { attributes.put(name, session.getAttribute(name)); } } } return true; } @Nullable private HttpSession getSession(ServerHttpRequest request) { if (request instanceof ServletServerHttpRequest serverRequest) { return serverRequest.getServletRequest().getSession(isCreateSession()); } return null; } @Override public void afterHandshake(ServerHttpRequest request, ServerHttpResponse response, WebSocketHandler wsHandler, @Nullable Exception ex) { } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy