Cookie:

1.保存在用户浏览器
2.可以主动清除
3.可以被伪造
4.跨域名 Cookie 不共享

创建一个项目:user_manager 和应用: app01

创建数据库,添加 models.py

from django.db import models
# Create your models here.
class Classes(models.Model):
  caption = models.CharField(max_length=32)
class Student(models.Model):
  name = models.CharField(max_length=32)
  cls = models.ForeignKey(Classes, on_delete=models.CASCADE)
class Teacher(models.Model):
  name = models.CharField(max_length=32)
  cls = models.ForeignKey(Classes, on_delete=models.CASCADE)
class Administrator(models.Model):
  username = models.CharField(max_length=32)
  password = models.CharField(max_length=32)
修改 urls.py
from django.contrib import admin
from django.urls import path
from app01 import views
urlpatterns = [
  path('admin/', admin.site.urls),
  path('login.html', views.login),
  path('index.html', views.index),
]

在 templates 文件夹下创建两个 html 文件

# login.html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<body>
<form action="login.html" method="post">
  {% csrf_token %}
  <div>
    <label for="user">用户名: </label>
    <input id="user" type="text" name="user">
  </div>
  <div>
    <label for="pwd">密码: </label>
    <input id="pwd" type="password" name="pwd">
  </div>
  <div>
    <label></label>
    <input type="submit" value="登录">
    <span style="color: red;">{{ msg }}</span>
  </div>
</form>

</body>
</html>

# index.html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<body>
<h1> Hello {{ username }} </h1>

</body>
</html>

添加 views.py

from django.shortcuts import render, redirect
# Create your views here.
from app01 import models
def login(req):
  # models.Administrator.objects.create(
  #   username='klvchen',
  #   password='klvchen'
  # )
  message = ""
  if req.method == "POST":
    user = req.POST.get('user')
    pwd = req.POST.get('pwd')
    c = models.Administrator.objects.filter(username=user, password=pwd).count()
    if c:
      rep = redirect('index.html')
      rep.set_cookie('username', user)
      return rep
    else:
      message = "用户名或密码错误"
  return render(req, 'login.html', {'msg': message})
def index(req):
  username = req.COOKIES.get('username')
  if username:
    return render(req, 'index.html', {'username': username})
  else:
    return redirect('/login.html')

初始化数据库

python manage.py makemigrations
python manage.py migrate

启动

python manage.py runserver 8000

访问 http://127.0.0.1:8000/index.html

输入错误的用户名或密码

Django 使用 cookie 实现简单的用户管理功能

输入正确的用户名和密码

Django 使用 cookie 实现简单的用户管理功能
Django 使用 cookie 实现简单的用户管理功能

总结

以上所述是小编给大家介绍的基于Django 使用 cookie 实现简单的用户管理功能,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

标签:
django,cookie,用户管理

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。