1
0
mirror of https://github.com/actix/actix-extras.git synced 2024-11-30 10:32:55 +01:00
actix-extras/actix-redis
2021-03-21 09:38:29 +00:00
..
examples Clean up deps and macro_use (#81) 2020-07-14 11:20:42 +01:00
src session, redis, and httpauth pre-v4 releases (#162) 2021-03-21 09:38:29 +00:00
tests move redis to own module 2020-01-29 11:41:40 +00:00
Cargo.toml session, redis, and httpauth pre-v4 releases (#162) 2021-03-21 09:38:29 +00:00
CHANGES.md session, redis, and httpauth pre-v4 releases (#162) 2021-03-21 09:38:29 +00:00
LICENSE-APACHE merge project metadata 2020-01-30 00:31:25 +00:00
LICENSE-MIT merge project metadata 2020-01-30 00:31:25 +00:00
README.md session, redis, and httpauth pre-v4 releases (#162) 2021-03-21 09:38:29 +00:00

actix-redis

Redis integration for Actix and session store for Actix Web.

crates.io Documentation Apache 2.0 or MIT licensed Dependency Status

Documentation & Resources

Redis Session Backend

Use redis as session storage.

You need to pass an address of the redis server and random value to the constructor of RedisSession. This is private key for cookie session, When this value is changed, all session data is lost.

Note that whatever you write into your session is visible by the user (but not modifiable).

Constructor panics if key length is less than 32 bytes.

use actix_web::{App, HttpServer, web, middleware};
use actix_web::middleware::session::SessionStorage;
use actix_redis::RedisSession;

#[actix_rt::main]
async fn main() -> std::io::Result {
    HttpServer::new(|| App::new()
        // enable logger
        .middleware(middleware::Logger::default())
        // cookie session middleware
        .middleware(SessionStorage::new(
            RedisSession::new("127.0.0.1:6379", &[0; 32])
        ))
        // register simple route, handle all methods
        .service(web::resource("/").to(index))
    )
    .bind("0.0.0.0:8080")?
    .start()
    .await
}