如果我们使用drf框架状态保持使用的是session的话,而不是jwt,那么我们的后台肯定要保存数据,用于对比验证,这样保存到那里就成了问题,
- 保存到mysql中,这是框架默认的存储地址,在setting中可以不用设置,但是这种当用户少的时候是没问题的,但是用户量很大的时候,服务器开销就会很大,影响性能
- 保存到缓存中redis中,这样的话查询速度就会很快,但是我们都知道redis数据一旦存储满的话,就会实行删除策略,这样会丢失一部分数据,导致用户状态无法保持,所以最好的办法就是 数据库-缓存 并用,两者都保持session,但是查询时从redis中查询,如果redis查询不到了,再从mysql中查询,这样的话,就会开销变小,建议选择这种方法,我们需要在setting中设置一下:
# cookie 过期时间 一年
COOKIE_MAX_AGE = 365*24*60*60
# session过期时间 7天
SESSION_COOKIE_AGE = 7 * 24 * 60 * 60
CACHES = {
# session状态保持
"session": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://127.0.0.1:6379/8",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
}
},
}
# session redis mysql中都保存,查询时先在redis中查找,找不到再去mysql中查找
SESSION_ENGINE = "django.contrib.sessions.backends.cached_db"
SESSION_CACHE_ALIAS = "session"
- 保存在文件系统中,也是在setting中设置:
SESSION_ENGINE = 'django.contrib.sessions.backends.file'
SESSION_FILE_PATH = 'xxx' # 文件位置(确保有权限,Django默认是系统的临时文件目录tempfile.gettempdir())