Django 2021年最新版教程13Cookie是什么 如何使用
Posted 软件工程小施同学
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django 2021年最新版教程13Cookie是什么 如何使用相关的知识,希望对你有一定的参考价值。
一、cookie是什么
Cookie 是存储在客户端计算机(浏览器)上的文本文件。
HTTP 是一种"无状态"协议,这意味着每次客户端检索网页时,
- 客户端打开一个单独的连接到 Web 服务器,
- 一个 Web 服务器可以分配一个唯一的 session 会话 ID 作为每个 Web 客户端的 cookie,也可以向浏览器发送一组 Cookie。例如:姓名、年龄或识别号码等。
- 对于客户端的后续请求, Web 服务器可以使用接收到的 cookie 来识别该用户。
二、Django 中 Cookie 的语法
1.设置 cookie:
rep =HttpResponse || render || redirect
rep.set_cookie(key,value,...)
rep.set_signed_cookie(key,value,salt='加密盐',...)
2. 获取 cookie:
request.COOKIES.get(key)
3.删除 cookie:
rep =HttpResponse || render || redirect
rep.delete_cookie(key)
三、实例
1. 新增testCookie.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<a href="/testoperatecookie?type=set"><button>设置cookie</button></a><br/>
<a href="/testoperatecookie?type=get"><button>获取cookie</button></a><br/>
<a href="/testoperatecookie?type=delete"><button>删除cookie</button></a>
</body>
</html>
2. 新增testCookie和testOperatorCookie函数
import datetime
import json
from django.core import serializers
from django.http import HttpResponse, JsonResponse
from django.shortcuts import render, redirect
# Create your views here.
from userWeb.models import User
def index(request):
return render(request, './userWeb/index.html')
# 加法页面
def add(request):
return render(request, './userWeb/add.html')
# 执行加法
def doadd(request):
a = request.POST['a']
b = request.POST['b']
a = int(a)
b = int(b)
result = a + b
# return HttpResponse(str(result))
context = {}
context['a'] = a
context['b'] = b
context['result'] = result
return render(request, './userWeb/add_result.html', context)
# 增加用户页面
def testUser(request):
return render(request, './userWeb/testUser.html')
# 执行增加用户
def testAddUser(request):
name = request.POST['name']
level = request.POST['level']
createTime = datetime.datetime.now()
user = User.objects.create(name=name, level=level, createTime=createTime)
context = {}
context['msg'] = '用户新增成功'
context['数据库中的id'] = user.id
return HttpResponse(str(context))
# 数据库查询
def testQueryUser(request):
total = User.objects.count() # 查询所有数据的总量
total_condition = User.objects.filter(level=2).count() # 查询符合条件的数据总量
all_user = User.objects.all() # 查询得到所有用户,使用 all() 方法来查询所有内容。可用索引下标取出模型类的对象。
all_user_condition = User.objects.filter(level=2) # 查询得到指定条件的所有用户
all_user_by_order = User.objects.filter(level=2).order_by('createTime') # 按创建时间从小到大排序,-createTime表示从大到小
a_user_by_id = User.objects.filter(pk=3) #pk=3 的意思是主键 primary key=3,相当于 id=3。因为 id 在 pycharm 里有特殊含义,是看内存地址的内置函数 id(),因此用 pk。
just_show_some_fields = User.objects.filter(pk=3).values("pk", "name") # 只显示id和name者两个字段
print(just_show_some_fields)
context = {}
context['total'] = total # 查询所有数据的总量
context['total_condition'] = total_condition # 查询符合条件的数据总量
context['all_user'] = serializers.serialize("json", all_user) # 查询得到所有用户,使用 all() 方法来查询所有内容。可用索引下标取出模型类的对象。
context['all_user_condition'] = serializers.serialize("json", all_user_condition) # 查询得到指定条件的所有用户
context['all_user_by_order'] = serializers.serialize("json", all_user_by_order) # 按创建时间从小到大排序,-createTime表示从大到小
context['a_user_by_id'] = serializers.serialize("json", a_user_by_id) #pk=3 的意思是主键 primary key=3,相当于 id=3。因为 id 在 pycharm 里有特殊含义,是看内存地址的内置函数 id(),因此用 pk。
#objects.values()返回django.db.models.query.QuerySet对象,需要将ValuesQuerySet对象需要先转换成list
context['just_show_some_fields'] = json.dumps(list(just_show_some_fields)) # 只显示id和name者两个字段
return JsonResponse(context)
# 数据库修改
def testUpdateUser(request):
# 查询出指定的用户
userid=request.GET.get('userid', None)
if userid is None:
return HttpResponse("必须传递userid参数")
# 修改前
before_update = User.objects.filter(pk=userid) #pk=3 的意思是主键 primary key=3,相当于 id=3。因为 id 在 pycharm 里有特殊含义,是看内存地址的内置函数 id(),因此用 pk。
context = {}
context['before_update'] = serializers.serialize("json", before_update)
# 将该用户的level修改为10,返回值:整数,受影响的行数
result = User.objects.filter(pk=userid).update(level=10)
# 修改后
after_update = User.objects.filter(pk=userid) #pk=3 的意思是主键 primary key=3,相当于 id=3。因为 id 在 pycharm 里有特殊含义,是看内存地址的内置函数 id(),因此用 pk。
context['after_update'] = serializers.serialize("json", after_update)
context['the_number_of_rows_affected'] = result
return JsonResponse(context)
# 数据库删除
def testDeleteUser(request):
# 将该用户的level修改为10,返回值:整数,受影响的行数
result = User.objects.filter(pk__in=[2,3]).delete()
context = {}
context['msg'] = "删除成功"
context['the_number_of_rows_affected'] = result
return JsonResponse(context)
# 测试cookie页面
def testCookie(request):
return render(request, './userWeb/testCookie.html')
# 执行测试cookie
def testOperateCookie(request):
type = request.GET.get('type', None)
if type == 'set':
rep = redirect("/testcookie")
rep.set_cookie("is_login", True)
return rep
elif type == 'get':
context = {}
context['is_login'] = request.COOKIES.get('is_login')
return JsonResponse(context)
elif type == 'delete':
rep = redirect("/testcookie")
rep.delete_cookie("is_login")
return rep
else:
return HttpResponse("参数不足")
3. 修改urls.py
4.效果
点击设置cookie
点击获取cookie
点击删除cookie
参考:https://www.runoob.com/django/django-cookie-session.html
以上是关于Django 2021年最新版教程13Cookie是什么 如何使用的主要内容,如果未能解决你的问题,请参考以下文章
Django 2021年最新版教程1windows10+python3.9.5+pycharm2021.1.1+Django3.2.3新建一个web项目 教程