com.phloc.web.servlet.session.SessionHelper Maven / Gradle / Ivy
/**
* Copyright (C) 2006-2015 phloc systems
* http://www.phloc.com
* office[at]phloc[dot]com
*
* 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
*
* http://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 com.phloc.web.servlet.session;
import java.util.Enumeration;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import javax.annotation.concurrent.Immutable;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpSession;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.phloc.commons.ValueEnforcer;
import com.phloc.commons.annotations.PresentForCodeCoverage;
import com.phloc.commons.collections.ContainerHelper;
import com.phloc.commons.lang.GenericReflection;
import com.phloc.commons.state.EChange;
import com.phloc.web.mock.MockHttpSession;
/**
* HTTP session utilities.
*
* @author Philip Helger
*/
@Immutable
public final class SessionHelper
{
private static final Logger s_aLogger = LoggerFactory.getLogger (SessionHelper.class);
@PresentForCodeCoverage
@SuppressWarnings ("unused")
private static final SessionHelper s_aInstance = new SessionHelper ();
private SessionHelper ()
{}
/**
* Invalidate the session if the session is still active.
*
* @param aSession
* The session to be invalidated. May be null
.
* @return {@link EChange#CHANGED} if the session was invalidated,
* {@link EChange#UNCHANGED} otherwise.
*/
@Nonnull
public static EChange safeInvalidateSession (@Nullable final HttpSession aSession)
{
if (aSession != null)
{
try
{
aSession.invalidate ();
return EChange.CHANGED;
}
catch (final IllegalStateException ex)
{
// session already invalidated
}
}
return EChange.UNCHANGED;
}
/**
* Get all attribute names present in the specified session.
*
* @param aSession
* The session to use. May not be null
.
* @return Never null
.
*/
@Nonnull
public static Enumeration getAllAttributes (@Nonnull final HttpSession aSession)
{
ValueEnforcer.notNull (aSession, "Session");
try
{
return GenericReflection., Enumeration > uncheckedCast (aSession.getAttributeNames ());
}
catch (final IllegalStateException ex)
{
// Session no longer valid
return ContainerHelper. getEmptyEnumeration ();
}
}
public static boolean isSessionValid (@Nullable final HttpSession aSession)
{
if (aSession == null)
{
return false;
}
if (aSession instanceof MockHttpSession)
{
return !((MockHttpSession) aSession).isInvalid ();
}
try
{
aSession.getAttributeNames ();
return true;
}
catch (final IllegalStateException aEx)
{
return false;
}
}
/**
* Invalidate the session of the specified request (if any) and create a new
* session.
*
* @param aHttpRequest
* The HTTP request to use. May not be null
.
* @return The new {@link HttpSession} to use. Never null
.
*/
@Nonnull
public static HttpSession safeRenewSession (@Nonnull final HttpServletRequest aHttpRequest)
{
ValueEnforcer.notNull (aHttpRequest, "HttpRequest");
// Is there any existing session?
final HttpSession aSession = aHttpRequest.getSession (false);
if (aSession != null)
{
try
{
s_aLogger.info ("Invalidating session " + aSession.getId ());
aSession.invalidate ();
}
catch (final IllegalStateException ex)
{
// session already invalidated
}
}
// Create the new session
return aHttpRequest.getSession (true);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy