目录
CookieSession
二、CookoeCookie,有时也用其复数形式Cookies,指某些网站为了辨别用户身份、进行session跟踪而储存在用户本地终端上的数据(通常经过加密)。Cookie最早是网景公司的前雇员Lou Montulli在1993年3月的发明。Cookie是由服务器端生成,发送给User-Agent(一般是浏览器),浏览器会将Cookie的key/value保存到某个目录下的文本文件内,下次请求同一网站时就发送该Cookie给服务器(前提是浏览器设置为启用cookie)。Cookie名称和值可以由服务器端开发自己定义,这样服务器可以知道该用户是否是合法用户以及是否需要重新登录等。服务器可以利用Cookies包含信息的任意性来筛选并经常性维护这些信息,以判断在HTTP传输中的状态。Cookies最典型记住用户名。
Cookie是存储在浏览器中的一段纯文本信息,建议不要存储敏感信息如密码,因为电脑上的浏览器可能被其它人使用。
第一次请求过程:
第二次及以后的请求过程:
可以通过HttpResponse对象中的set_cookie方法来设置cookie。
HttpResponse.set_cookie(cookie名, value=cookie值, max_age=cookie有效期)
示例:
- def cookie(request):
- response = HttpResponse('ok')
- response.set_cookie('itcast1', 'python1') # 临时cookie
- response.set_cookie('itcast2', 'python2', max_age=3600) # 有效期一小时
- return response
可以通过HttpResponse对象的COOKIES属性来读取本次请求携带的cookie值。request.COOKIES为字典类型。
- def cookie(request):
- cookie1 = request.COOKIES.get('itcast1')
- print(cookie1)
- return HttpResponse('OK')
可以通过HttpResponse对象中的delete_cookie方法来删除。
response.delete_cookie('itcast2')
三、Session与cookie不同(cookie是保存在客户端)session是保存在服务端的,session依赖于cookie,在使用session后,会在cookie中存储一个sessionid的数据,每次请求时浏览器都会将这个数据发给服务器,服务器在接收到sessionid后,会根据这个值找出这个请求者的Session。
Django项目默认启用Session。
可以在settings.py文件中查看,如图所示

如需禁用session,将上图中的session中间件注释掉即可。
第一次请求:
第二次及其之后的请求:
在settings.py文件中,可以设置session数据的存储方式,可以保存在数据库、本地缓存等。
3.1、存储在数据库中:
如下设置可以写,也可以不写,这是默认存储方式。
SESSION_ENGINE='django.contrib.sessions.backends.db'
如果存储在数据库中,需要在项INSTALLED_APPS中安装Session应用。

数据库中的表如图所示

表结构如下

由表结构可知,操作Session包括三个数据:键,值,过期时间。
3.2、存储在本机内存中:
如果丢失则不能找回,比数据库的方式读写更快。
SESSION_ENGINE='django.contrib.sessions.backends.cache'
3.3、混合存储:
优先从本机内存中存取,如果没有则从数据库中存取。
SESSION_ENGINE='django.contrib.sessions.backends.cached_db'
通过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)