Struct actix_session::storage::CookieSessionStore
source · #[non_exhaustive]pub struct CookieSessionStore;
Expand description
Use the session key, stored in the session cookie, as storage backend for the session state.
use actix_web::{cookie::Key, web, App, HttpServer, HttpResponse, Error};
use actix_session::{SessionMiddleware, storage::CookieSessionStore};
// The secret key would usually be read from a configuration file/environment variables.
fn get_secret_key() -> Key {
// [...]
}
#[actix_web::main]
async fn main() -> std::io::Result<()> {
let secret_key = get_secret_key();
HttpServer::new(move ||
App::new()
.wrap(SessionMiddleware::new(CookieSessionStore::default(), secret_key.clone()))
.default_service(web::to(|| HttpResponse::Ok())))
.bind(("127.0.0.1", 8080))?
.run()
.await
}
§Limitations
Cookies are subject to size limits so we require session keys to be shorter than 4096 bytes. This translates into a limit on the maximum size of the session state when using cookies as storage backend.
The session cookie can always be inspected by end users via the developer tools exposed by their
browsers. We strongly recommend setting the policy to CookieContentSecurity::Private
when
using cookies as storage backend.
There is no way to invalidate a session before its natural expiry when using cookies as the storage backend.
Trait Implementations§
source§impl Default for CookieSessionStore
impl Default for CookieSessionStore
source§fn default() -> CookieSessionStore
fn default() -> CookieSessionStore
Returns the “default value” for a type. Read more
source§impl SessionStore for CookieSessionStore
impl SessionStore for CookieSessionStore
source§async fn load(
&self,
session_key: &SessionKey
) -> Result<Option<HashMap<String, String>>, LoadError>
async fn load( &self, session_key: &SessionKey ) -> Result<Option<HashMap<String, String>>, LoadError>
Loads the session state associated to a session key.
source§async fn save(
&self,
session_state: HashMap<String, String>,
_ttl: &Duration
) -> Result<SessionKey, SaveError>
async fn save( &self, session_state: HashMap<String, String>, _ttl: &Duration ) -> Result<SessionKey, SaveError>
Persist the session state for a newly created session. Read more
source§async fn update(
&self,
_session_key: SessionKey,
session_state: HashMap<String, String>,
ttl: &Duration
) -> Result<SessionKey, UpdateError>
async fn update( &self, _session_key: SessionKey, session_state: HashMap<String, String>, ttl: &Duration ) -> Result<SessionKey, UpdateError>
Updates the session state associated to a pre-existing session key.
source§async fn update_ttl(
&self,
_session_key: &SessionKey,
_ttl: &Duration
) -> Result<(), Error>
async fn update_ttl( &self, _session_key: &SessionKey, _ttl: &Duration ) -> Result<(), Error>
Updates the TTL of the session state associated to a pre-existing session key.
Auto Trait Implementations§
impl Freeze for CookieSessionStore
impl RefUnwindSafe for CookieSessionStore
impl Send for CookieSessionStore
impl Sync for CookieSessionStore
impl Unpin for CookieSessionStore
impl UnwindSafe for CookieSessionStore
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more