系列文章目录
[Python]目录
视频及资料和课件
链接:https://pan.baidu.com/s/1LCv_qyWslwB-MYw56fjbDg?pwd=1234
提取码:1234
文章目录
- 前言
- 1. 状态保持
- 2. Cookie
- 2.1 Cookie简介
- 2.2 Cookie的流程
- 2.3 Cookie的特点
- 2.4 设置Cookie
- 2.5 读取Cookie
- 2.6 删除Cookie
- 2.7 从http协议角度理解Cookie的流程
- 3. Session
- 3.1 Session简介
- 3.2 Session流程
- 3.3 启用Session
- 3.4 Session的存储位置
- 3.5 设置Session
- 3.6 读取Session
- 3.7 从http协议角度理解session的流程
- 3.8 清除所有session的值部分
- 3.9 清除所有session的整条数据
- 3.10 清除指定session的键及值
- 3.11 设置session的有效期
浏览器请求服务器是无状态的。
无状态:指一次用户请求时,浏览器、服务器无法知道之前这个用户做过什么,每次请求都是一次新的请求。
无状态原因:浏览器与服务器是使用Socket套接字进行通信的,服务器将请求结果返回给浏览器之后,会关闭当前的Socket连接,而且服务器也会在处理页面完毕之后销毁页面对象。
有时需要保持下来用户浏览的状态,比如用户是否登录过,浏览过哪些商品等
实现状态保持主要有两种方式:
Cookie,有时也用其复数形式Cookies,指某些网站为了辨别用户身份、进行session跟踪而储存在用户本地终端上的数据(通常经过加密)。
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有效期)
项目/urls.py:
urlpatterns = [
path('admin/', admin.site.urls),
path('login/', include(('login.urls', 'login'), namespace='login')),
path('book/', include(('book.urls', 'book'), namespace='book'))
]
login/urls.py:
from django.urls import path
from login import views
urlpatterns = [
path('', views.login),
path('set_cookie', views.set_cookie)
]
login/views.py:
from django.shortcuts import render
from django.http import HttpRequest
from django.http import HttpResponse
from django.http import JsonResponse
from django.shortcuts import redirect
from django.urls import reverse
# Create your views here.
def set_cookie(request):
response = HttpResponse('set_cookie')
# 在响应中设置Cookie为 username=zs
response.set_cookie('username', value='zs')
# 返回响应
return response
可以通过HttpResponse对象的COOKIES属性来读取本次请求携带的cookie值。
request.COOKIES
为字典类型。
login/urls.py:
from django.urls import path
from login import views
urlpatterns = [
path('', views.login),
path('set_cookie/', views.set_cookie),
path('get_cookie/', views.get_cookie)
]
login/views.py:
from django.shortcuts import render
from django.http import HttpRequest
from django.http import HttpResponse
from django.http import JsonResponse
from django.shortcuts import redirect
from django.urls import reverse
import json
# Create your views here.
def set_cookie(request):
response = HttpResponse('set_cookie')
# 在响应中设置Cookie为 username=zs
response.set_cookie('username', value='zs')
# 返回响应
return response
def get_cookie(request):
# 获取浏览器请求时携带的cookie
cookies = request.COOKIES
print('cookies: ', cookies)
print('cookies_type: ', type(cookies))
# 获取cookie中的用户名
# 由于cookies是字典类型,所以可以使用字典方式获取cookie中某一个值
username = cookies['username']
print('username: ', username)
# 将cookie以JSON字符串的形式返回给浏览器
return JsonResponse(cookies)
可以通过HttpResponse对象中的delete_cookie方法来删除。
语法:
HttpResponse.delete_cookie('cookie名')
login/urls.py:
from django.urls import path
from login import views
urlpatterns = [
path('', views.login),
path('set_cookie/', views.set_cookie),
path('get_cookie/', views.get_cookie),
path('del_cookie/', views.del_cookie)
]
login/views.py:
from django.shortcuts import render
from django.http import HttpRequest
from django.http import HttpResponse
from django.http import JsonResponse
from django.shortcuts import redirect
from django.urls import reverse
import json
# Create your views here.
def set_cookie(request):
response = HttpResponse('set_cookie')
# 在响应中设置Cookie为 username=zs
response.set_cookie('username', value='zs')
# 返回响应
return response
def get_cookie(request):
# 获取浏览器请求时携带的cookie
cookies = request.COOKIES
print('cookies: ', cookies)
print('cookies_type: ', type(cookies))
# 获取cookie中的用户名
# 由于cookies是字典类型,所以可以使用字典方式获取cookie中某一个值
username = cookies['username']
print('username: ', username)
# 将cookie以JSON字符串的形式返回给浏览器
return JsonResponse(cookies)
def del_cookie(request):
response = HttpResponse('del_cookie')
# 由于不为第一次请求,cookie存在,返回响应时,会将发送过来的cookie返回
# 删除响应对象中的cookie
response.delete_cookie('username')
# 返回响应
return response
删除Cookie,也可通过将Cookie的有效时间设置为0实现:
HttpResponse.set_cookie(key, value, max_age=0)
保存在服务器的数据,叫做Session。Session需要依赖于Cookie,如果浏览器禁用了Cookie,则Session不能实现。因为设置session会生成一个sessionid保存cookie中响应给客户端,之后客户端再次发送请求,cookie中的sessionid没问题,可以直接获取session中的数据。
sessionid由服务器自动设置
Django项目默认启用Session。
如需禁用session,将上图中的session中间件注释掉即可。
通过HttpRequest对象的session属性对Session进行读写操作。
HttpRequest.session
可以理解为字典,可以以键值对的格式设置session。
我们在设置session时,session做了2件事,将数据保存在数据库中,设置一个cookie信息,这个cookie信息以sessionid为key
如果sessionid已经存在,则不会再次生成,只会对session中的数据进行更新
语法:
request.session['键']=值
login/urls.py:
from django.urls import path
from login import views
urlpatterns = [
path('', views.login),
path('set_cookie/', views.set_cookie),
path('get_cookie/', views.get_cookie),
path('del_cookie/', views.del_cookie),
path('set_session/', views.set_session)
]
login/views.py:
from django.shortcuts import render
from django.http import HttpRequest
from django.http import HttpResponse
from django.http import JsonResponse
from django.shortcuts import redirect
from django.urls import reverse
import json
# Create your views here.
def set_session(request):
# 1. 获取浏览器传递的Cookie
# 第一次请求没有cookie
cookies = request.COOKIES
print(cookies)
# 2. 用户名和密码进行验证
# 假设认为用户名和密码正确
username = 'zszszs'
# 3. 设置session信息
# request.session可以理解为字典
# 服务器会自动在响应头中设置一个session id
request.session['username'] = username
# 4. 返回响应
return HttpResponse('set_session')
通过HttpRequest对象的session属性对Session进行读写操作。
HttpRequest.session
可以理解为字典,可以根据键读取Session值。
语法:
request.session.get('键',默认值)
login/urls.py:
from django.urls import path
from login import views
urlpatterns = [
path('', views.login),
path('set_cookie/', views.set_cookie),
path('get_cookie/', views.get_cookie),
path('del_cookie/', views.del_cookie),
path('set_session/', views.set_session),
path('get_session/', views.get_session)
]
login/views.py:
def get_session(request):
# 1. 请求会通过cookie将session id发送给服务器
cookies = request.COOKIES
print(cookies)
# 2. 获取session id,进行验证
# 浏览器发送过来的请求cookie会携带session id
# cookie中的session id没问题可以直接获取session中的信息
# 验证成功获取session信息
# request.session相当于字典
username = request.session.get('username')
print(username)
# 3. 返回响应
return HttpResponse('get_session')
清除所有session在存储中的值部分。
语法:
request.session.clear()
清除所有session在存储中的整条数据。
语法:
request.session.flush()
删除session中的指定键及值,在存储中只删除某个键及对应的值。
语法:
del request.session['键']
语法:
request.session.set_expiry(value)