Django 中 Session 的储存和操作

Django Session详解
本文深入讲解Django框架中Session的启用、存储方式及其操作方法,包括数据库、本地缓存、混合存储和Redis存储的设置与配置,以及如何通过HttpRequest对象进行会话的读写、清除和设置有效期。

一、启用Session:

Django项目默认启用Session。

可以在settings.py文件中查看,如图所示

如需禁用session,将上图中的session中间件注释掉即可。


二、存储方式:

在settings.py文件中,可以设置session数据的存储方式,可以保存在数据库、本地缓存等。

2.1 数据库

存储在数据库中,如下设置可以写,也可以不写,这是默认存储方式

SESSION_ENGINE='django.contrib.sessions.backends.db'

如果存储在数据库中,需要在项INSTALLED_APPS中安装Session应用。

数据库中的表如图所示:

表结构如下:

由表结构可知,操作Session包括三个数据:键,值,过期时间。

2.2 本地缓存:

存储在本机内存中,如果丢失则不能找回,比数据库的方式读写更快。

SESSION_ENGINE='django.contrib.sessions.backends.cache'

2.3 混合存储:

优先从本机内存中存取,如果没有则从数据库中存取。

SESSION_ENGINE='django.contrib.sessions.backends.cached_db'

2.4 Redis存储:

在redis中保存session,需要引入第三方扩展,我们可以使用django-redis来解决。

1、安装扩展

pip install django-redis

2、配置,在settings.py文件中做如下设置

CACHES = {
    "default": {
        "BACKEND": "django_redis.cache.RedisCache",
        "LOCATION": "redis://127.0.0.1:6379/1",
        "OPTIONS": {
            "CLIENT_CLASS": "django_redis.client.DefaultClient",
        }
    }
}
SESSION_ENGINE = "django.contrib.sessions.backends.cache"
SESSION_CACHE_ALIAS = "default"

注意:

如果redis的ip地址不是本地回环127.0.0.1,而是其他地址,访问Django时,可能出现Redis连接错误,如下:

解决方法:

修改redis的配置文件,添加特定ip地址。

1、打开redis的配置文件

sudo vim /etc/redis/redis.conf

2、在如下配置项进行修改(添加本机的 IP 地址:10.211.55.5地址)

3、重新启动redis服务:

sudo service redis-server restart

三、Session操作

通过HttpRequest对象的session属性进行会话的读写操作。

1、以键值对的格式写session。

request.session['键']=值

2、根据键读取值。

request.session.get('键',默认值)

3、清除所有session,在存储中删除值部分。

request.session.clear()

4、清除session数据,在存储中删除session的整条数据。

request.session.flush()

5、删除session中的指定键及值,在存储中只删除某个键及对应的值。

del request.session['键']

6、设置session的有效期

request.session.set_expiry(value)
  • 如果value是一个整数,session将在value秒没有活动后过期。
  • 如果value为0,那么用户session的Cookie将在用户的浏览器关闭时过期。
  • 如果value为None,那么session有效期将采用系统默认值,默认为两周,可以通过在settings.py中设置SESSION_COOKIE_AGE来设置全局默认值。
Django中,Session是一种常用的在客户端浏览器之间持久存储数据的方式,用于维持用户的会话状态。以下是关于Django中设置管理Session的详细步骤: 1. **启用Session**: 首先,在`settings.py`文件中确保`SESSION_ENGINE`设置为默认的数据库存储引擎(如'django.contrib.sessions.backends.db'),并在`MIDDLEWARE`列表中添加`django.middleware.sessions.SessionMiddleware`。 2. **配置中间件**: 在`MIDDLEWARE`中配置session中间件,确保它在其他认证内容安全中间件之后,因为Session需要在页面加载后立即可用。 3. **开始会话**: 每次用户访问网站时,都需要创建一个新的Session。这通常发生在视图函数的开始部分,通过`request.session`对象,你可以设置键值对: ```python request.session['username'] = user.username ``` 4. **获取更新Session**: 要获取已保存的数据,可以在任何地方使用`request.session`,例如在模板中: ```html <p>Welcome, {{ request.session.get('username') }}</p> ``` 5. **结束会话**: 如果不需要数据了,可以明确地结束当前会话: ```python request.session.flush() ``` 或者在响应中设置`HttpResponse.delete_cookie()`来删除特定的Cookie(这将终止会话)。 6. **保存会话**: Django会在服务器端定期自动保存Session,但如果设置了`SESSION_SAVE_EVERY_REQUEST`为True,则每次请求都会保存。如果不需要频繁保存,可以在`settings.py`中调整这个选项。 7. **跨域会话**: 如果你需要跨域名共享Session,可以在项目级别设置允许来自特定域名的cookies: ```python SESSION_COOKIE_DOMAIN = '.yourdomain.com' ```
评论 8
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值