django中session的存储位置

django-session 存放位置

设置session的保存位置,有三种方法:

  1. 保存在关系数据库(db)
  2. 保存在缓存数据库(cache) 或者 关系+缓存数据库(cache_db)
  3. 保存在文件系统中(file)

第一种

保存在数据库中:需要在 INSTALL_APPS 中添加:django.contrib.sessions(默认创建项目的时候添加),然后,迁移一下

第二种

保存在缓存中

  1. 只保存在cache中 
    注:Django默认配置

    SESSION_ENGINE = ‘django.contrib.sessions.backends.db’

    修改为:

    SESSION_ENGINE = ‘django.contrib.sessions.backends.cache’

    有可能因内存溢出而导致找不到

  2. db和cache都保存,查找的时候先取cache中查找,找不到再转到db中查找

    修改为: 
    SESSION_ENGINE = ‘django.contrib.sessions.backends.cache_db’ 
    更安全,推荐

第三种

保存在文件系统中:

配置:

SESSION_ENGINE = 'django.contrib.sessions.backends.file'
SESSION_FILE_PATH = 'xxx' # 文件位置(确保有权限,Django默认是系统的临时文件目录tempfile.gettempdir())
  • 1
  • 2

补充1

a. 配置 settings.py 关于session的默认配置

SESSION_ENGINE = 'django.contrib.sessions.backends.db'   # 引擎(默认)

SESSION_COOKIE_NAME = "sessionid"                       # Session的cookie保存在浏览器上时的key,即:sessionid=随机字符串(默认)
SESSION_COOKIE_PATH = "/" # Session的cookie保存的路径(默认)
SESSION_COOKIE_DOMAIN = None # Session的cookie保存的域名(默认)
SESSION_COOKIE_SECURE = False # 是否Https传输cookie(默认)
SESSION_COOKIE_HTTPONLY = True # 是否Session的cookie只支持http传输(默认)
SESSION_COOKIE_AGE = 1209600 # Session的cookie失效日期(2周)(默认)
SESSION_EXPIRE_AT_BROWSER_CLOSE = False # 是否关闭浏览器使得Session过期(默认)
SESSION_SAVE_EVERY_REQUEST = False # 是否每次请求都保存Session,默认修改之后才保存(默认)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

补充2

如何把Django的session放到redis数据库中

直接使用django-redis-session库

1⃣️ pip install django-redis-sessions

2⃣️ 配置:
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
   SESSION_ENGINE = 'redis_sessions.session'
SESSION_REDIS = {
'host': 'localhost',
'port': 6379,
'db': 0,
'password': 'password',
'prefix': 'session',
'socket_timeout': 1
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

补充3

如何把缓存设置成redis:

CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://127.0.0.1:6379/0",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
}
}
}
上一篇:各个 Maven仓库 镜像(包括国内)


下一篇:不用写软件,纯JS 实现QQ空间自动点赞