@Experimental @ThreadSafe @Provider public interface SessionData
Unlike a cache, this session data is not subject to purging. For this same reason, session data should also not be abused as a cache (i.e. for storing values that can be re-calculated) to avoid memory exhaustion.
Note: Actual implementations must be thread-safe.
Session.getData()
Modifier and Type | Method and Description |
---|---|
Object |
computeIfAbsent(Object key,
Supplier<Object> supplier)
Retrieve of compute the data associated with the specified key.
|
Object |
get(Object key)
Gets the session data associated with the specified key.
|
void |
set(Object key,
Object value)
Associates the specified session data with the given key.
|
boolean |
set(Object key,
Object oldValue,
Object newValue)
Associates the specified session data with the given key if the key is currently mapped to the given value.
|
void set(@Nonnull Object key, @Nullable Object value)
key
- The key under which to store the session data, must not be null
.value
- The data to associate with the key, may be null
to remove the mapping.boolean set(@Nonnull Object key, @Nullable Object oldValue, @Nullable Object newValue)
key
- The key under which to store the session data, must not be null
.oldValue
- The expected data currently associated with the key, may be null
.newValue
- The data to associate with the key, may be null
to remove the mapping.true
if the key mapping was successfully updated from the old value to the new value,
false
if the current key mapping didn't match the expected value and was not updated.@Nullable Object get(@Nonnull Object key)
key
- The key for which to retrieve the session data, must not be null
.null
if none.@Nullable Object computeIfAbsent(@Nonnull Object key, @Nonnull Supplier<Object> supplier)
key
- The key for which to retrieve the session data, must not be null
.supplier
- The supplier will compute the new value.Copyright © 2001–2022 The Apache Software Foundation. All rights reserved.