Python 官方文档:入门教程 => 点击学习
目录引子为什么需要状态保持如何实现状态保持Cookie✨ Cookie的工作原理✨ Cookie的特点✨ Cookie与Django服务器执行流程配置Cookie读取CookieSe
之前在学习Django时,对状态保持这个概念很模糊,不知道怎么去保持,通过什么去实现保持都不太清楚;稍微花了一点时间,把状态保持的基本概念,使用cookie与session进行存储以及基本操作搭配图文给理清了;阅读本文大约需要 15min
因为通常浏览器请求服务器是 无状态 的,一次用户请求时,浏览器、服务器无法知道之前这个用户做过什么,每次请求都是一次新的请求。
无状态原因:浏览器与服务器是使用Socket套接字进行通信的,服务器将请求结果返回给浏览器之后,会关闭当前的Socket连接,而且服务器也会在处理页面完毕之后销毁页面对象。
因此可以使用状态保持来实现保持用户浏览的状态,比如用户是否登录过,浏览过哪些商品等
实现状态保持主要有两种方式:
Cookie
Session
由于Http是一种无状态的协议,服务器单从网络连接上无从知道客户身份。怎么办呢?
就给客户端们颁发一个通行证吧,每人一个,无论谁访问都必须携带自己通行证。这样服务器就能从通行证上确认客户身份了。
通过 HttpResponse
对象中的 set_cookie 方法来设置cookie。
HttpResponsse.set_cookit(sookie名, value=cookie值, max_age=cookie有效期)
写法: 设置存储的键值,设置存储事件
def cookie(request):
response = HttpResponse('ok')
response.set_cookie('make', 'golang') # 临时cookie
response.set_cookie('luxor', 'PHP', max_age=3600) # 有效期一小时
# max_age 单位为秒, 默认为None. 如果是临时cookie, 可将max_age设置为None.
可以通过 HttpResponse 对象的 COOKIES 属性来读取本次请求携带的cookie值。request.COOKIES为字典类型。
def cookie(request):
cookie1 = request.COOKIES.get('make')
print(cookie1)
return HttpResponse('OK')
Django完全支持也匿名会话,简单说就是使用跨网页之间可以进行通讯,比如显示用户名,用户是否已经发表评论。session框架让你 存储和获取访问者的数据信息 ,这些信息保存在服务器上(默认是数据库中),以 cookies 的方式发送和获取一个包含 session ID的值,并不是用cookies传递数据本身。
编辑 settings.py
中的一些配置
MIDDLEWARE_CLASSES 确保其中包含以下内容
'django.contrib.sessions.middleware.SessionMiddleware',
存储在数据库中,如下设置可以写,也可以不写,这是默认存储方式。
SESSION_ENGINE='django.contrib.sessions.backends.db'
如果存储在数据库中,需要在项 INSTALLED_APPS 中安装Session应用。
'django.contrib.sessions',
这些是默认启用的。如果你不用的话,也可以关掉这个以节省一点服务器的开销。
数据库中的表如图所示
由表结构可知,操作Session包括三个数据:键,值,过期时间。
存储在本机内存中,如果丢失则不能找回,比数据库的方式读写更快。
SESSION_ENGINE='django.contrib.sessions.backends.cache'
优先从本机内存中存取,如果没有则从数据库中存取。
SESSION_ENGINE='django.contrib.sessions.backends.cached_db'
创建模拟登录视图
def testsession(request):
# 更新数据库的session数据
request.session['name'] = 'Shrimps'
request.session['age'] = 22
request.session['userid'] = 1024
return HttpResponse('Good')
创建模拟主页视图
from django.http import HttpResponse
def testIndex(request):
# 查询主页的数据
userid = request.session.get('userid')
name = request.session.get('name')
if userid:
print('登陆过')
return HttpResponse(f'Hello - {name} ')
else:
print('未登录')
return HttpResponse('未登录')
登录后访问主页
在这里我是定义时间事件 所以才会显示晚上好
# 代码如下 - (在 return HttpResponse('Good') 之前执行)
# 判断当前时间
now_time = datetime.datetime.now().strftime('%H')
now_time = int(now_time)
if now_time > 12 and now_time < 18:
now_time = '下午好'
elif now_time < 12:
now_time = '早上好'
else:
now_time = '晚上好'
通过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规则:
settings.py
中设置SESSION_COOKIE_AGE来设置全局默认值。到此这篇关于Django 状态保持搭配与存储的实现的文章就介绍到这了,更多相关Django 状态保持搭配与存储内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: Django状态保持搭配与存储的实现
本文链接: https://lsjlt.com/news/118508.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0