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 实现简单的用户管理功能,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
问题内容: 我正在尝试通过Cookie管理我的用户。这不是那么容易,因为绝对没有关于此主题的文档。 借助示例“ zentask”,我做到了: 我正在这样使用它: 现在我有几个问题/问题: 1.)Cookie不会被删除,并且看起来总是一样的。例如bdb7f592f9d54837995f816498c0474031d44c1a-用户名%3Akantaki 2.)Security.Authenticat
本文向大家介绍使用Angular.js实现简单的购物车功能,包括了使用Angular.js实现简单的购物车功能的使用技巧和注意事项,需要的朋友参考一下 先给大家分享实现代码,在代码下面有效果图展示,大家可以两者结合参考下,废话不多说了,具体代码如下所示: 效果图展示如下: 以上所述是小编给大家介绍的使用Angular.js实现简单的购物车功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编
本文向大家介绍使用Python实现简单的服务器功能,包括了使用Python实现简单的服务器功能的使用技巧和注意事项,需要的朋友参考一下 socket接口是实际上是操作系统提供的系统调用。socket的使用并不局限于Python语言,你可以用C或者Java来写出同样的socket服务器,而所有语言使用socket的方式都类似(Apache就是使用C实现的服务器) Web框架就是提前写好了服务器。不能
本文向大家介绍Vue+Node实现的商城用户管理功能示例,包括了Vue+Node实现的商城用户管理功能示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Vue+Node实现的商城用户管理功能。分享给大家供大家参考,具体如下: 1、用户登陆 前端将用户输入的用户名密码post发送到后端,如果返回status=0,代表登陆成功,将hasLogin置为true,控制页面登陆按钮不显示,并显示返
本文向大家介绍DataGridView使用BindingNavigator实现简单分页功能,包括了DataGridView使用BindingNavigator实现简单分页功能的使用技巧和注意事项,需要的朋友参考一下 上篇文章给大家介绍DataGridView使用自定义控件实现简单分页功能,本篇使用BindingNavigator来实现简单分页功能。其实也只是借用了一个BindingNavigato
本文向大家介绍bootstrap使用validate实现简单校验功能,包括了bootstrap使用validate实现简单校验功能的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了bootstrap validate校验功能,供大家参考,具体内容如下 如果大家还想深入学习,可以点击这里进行学习,再为大家附3个精彩的专题: Bootstrap学习教程 Bootstrap实战教程 Boot