django 快速实现完整登录系统(cookie)
经过前面几节的练习,我们已经熟悉了django 的套路,这里来实现一个比较完整的登陆系统,其中包括注册、登陆、以及cookie的使用。
本操作的环境:
===================
deepin linux 2013(基于ubuntu)
python 2.7
Django 1.6.2
===================
创建项目与应用
#创建项目 fnngj@fnngj-H24X:~/djpy$ django-admin.py startproject mysite5 fnngj@fnngj-H24X:~/djpy$ cd mysite5 #在项目下创建一个online应用 fnngj@fnngj-H24X:~/djpy/mysite5$ python manage.py startapp online
目录结构如下:
打开mysite5/mysite5/settings.py文件,将应用添加进去:
![复制代码](http://common.cnblogs.com/images/copycode.gif)
# Application definition INSTALLED_APPS = ( django.contrib.admin, django.contrib.auth, django.contrib.contenttypes, django.contrib.sessions, django.contrib.messages, django.contrib.staticfiles, online, )
![复制代码](http://common.cnblogs.com/images/copycode.gif)
设计数据库
打开mysite5/online/models.py文件,添加如下内容:
![复制代码](http://common.cnblogs.com/images/copycode.gif)
from django.db import models # Create your models here. class User(models.Model): username = models.CharField(max_length=50) password = models.CharField(max_length=50) def __unicode__(self): return self.username
![复制代码](http://common.cnblogs.com/images/copycode.gif)
创建数据库,创建User表,用户名和密码两个字段。
下面进行数据库的同步:
![复制代码](http://common.cnblogs.com/images/copycode.gif)
fnngj@fnngj-H24X:~/djpy/mysite5$ python manage.py syncdb Creating tables ... Creating table django_admin_log Creating table auth_permission Creating table auth_group_permissions Creating table auth_group Creating table auth_user_groups Creating table auth_user_user_permissions Creating table auth_user Creating table django_content_type Creating table django_session Creating table online_user You just installed Djangos auth system, which means you dont have any superusers defined. Would you like to create one now? (yes/no): yes 输入yes/no Username (leave blank to use fnngj): 用户名(默认当前系统用户名) Email address: fnngj@126.com 邮箱地址 Password: 密码 Password (again): 确认密码 Superuser created successfully. Installing custom SQL ... Installing indexes ... Installed 0 object(s) from 0 fixture(s)
![复制代码](http://common.cnblogs.com/images/copycode.gif)
最后生成的 online_user 表就是我们models.py 中所创建的User类。
配置URL
打开mysite5/mysite5/urls.py:
![复制代码](http://common.cnblogs.com/images/copycode.gif)
from django.conf.urls import patterns, include, url from django.contrib import admin admin.autodiscover() urlpatterns = patterns(, # Examples: # url(r^$, mysite5.views.home, name=home), url(r^admin/, include(admin.site.urls)), url(r^online/, include(online.urls)), )
![复制代码](http://common.cnblogs.com/images/copycode.gif)
在mysite5/online/目录下创建urls.py文件:
![复制代码](http://common.cnblogs.com/images/copycode.gif)
from django.conf.urls import patterns, url from online import views
url(r^login/$,views.login,name = login), url(r^regist/$,views.regist,name = regist), url(r^index/$,views.index,name = index), url(r^logout/$,views.logout,name = logout), )
![复制代码](http://common.cnblogs.com/images/copycode.gif)
http://127.0.0.1:8000/online/ 登陆页
http://127.0.0.1:8000/online/login/ 登陆页
http://127.0.0.1:8000/online/regist/ 注册页
http://127.0.0.1:8000/online/index/ 登陆成功页
http://127.0.0.1:8000/online/logout/ 注销
创建视图
打开mysite5/online/views.py 文件:
![复制代码](http://common.cnblogs.com/images/copycode.gif)
#coding=utf-8 from django.shortcuts import render,render_to_response from django.http import HttpResponse,HttpResponseRedirect from django.template import RequestContext from django import forms from models import User class UserForm(forms.Form): username = forms.CharField(label=用户名,max_length=100) password = forms.CharField(label=密码,widget=forms.PasswordInput())
User.objects.create(username= username,password=password) return HttpResponse(regist success!!) else: uf = UserForm() return render_to_response(regist.html,{uf:uf}, context_instance=RequestContext(req)) def login(req): if req.method == POST: uf = UserForm(req.POST) if uf.is_valid(): #获取表单用户密码 username = uf.cleaned_data[username] password = uf.cleaned_data[password] #获取的表单数据与数据库进行比较 user = User.objects.filter(username__exact = username,password__exact = password) if user: #比较成功,跳转index response = HttpResponseRedirect(/online/index/) #将username写入浏览器cookie,失效时间为3600 response.set_cookie(username,username,3600) return response else: #比较失败,还在login return HttpResponseRedirect(/online/login/) else: uf = UserForm() return render_to_response(login.html,{uf:uf},context_instance=RequestContext(req)) #登陆成功 def index(req): username = req.COOKIES.get(username,) return render_to_response(index.html ,{username:username}) def logout(req): response = HttpResponse(logout !!) #清理cookie里保存username response.delete_cookie(username) return response
![复制代码](http://common.cnblogs.com/images/copycode.gif)
这里实现了所有注册,登陆逻辑,中间用到cookie创建,读取,删除操作等。
创建模板
先在mysite5/online/目录下创建templates目录,接着在mysite5/online/templates/目录下创建regist.html 文件:
![复制代码](http://common.cnblogs.com/images/copycode.gif)
?xml version="1.0" encoding="UTF-8"? !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en" head meta http-equiv="Content-Type" content="text/html; charset=UTF-8" / title 注册 /title /head body h1 注册页面: /h1 form method = post enctype="multipart/form-data" {% csrf_token %} {{uf.as_p}} input type="submit" value = "ok" / /form a href="http://127.0.0.1:8000/online/login/" 登陆 /a /body /html
![复制代码](http://common.cnblogs.com/images/copycode.gif)
mysite5/online/templates/目录下创建login.html 文件:
![复制代码](http://common.cnblogs.com/images/copycode.gif)
?xml version="1.0" encoding="UTF-8"? !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en" head meta http-equiv="Content-Type" content="text/html; charset=UTF-8" / title 登陆 /title /head body h1 登陆页面: /h1 form method = post enctype="multipart/form-data" {% csrf_token %} {{uf.as_p}} input type="submit" value = "ok" / /form a href="http://127.0.0.1:8000/online/regist/" 注册 /a /body /html
![复制代码](http://common.cnblogs.com/images/copycode.gif)
mysite5/online/templates/目录下创建index.html 文件:
![复制代码](http://common.cnblogs.com/images/copycode.gif)
?xml version="1.0" encoding="UTF-8"? !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en" head meta http-equiv="Content-Type" content="text/html; charset=UTF-8" / title /title /head body h1 welcome {{username}} ! /h1 a href="http://127.0.0.1:8000/online/logout/" 退出 /a /body /html
![复制代码](http://common.cnblogs.com/images/copycode.gif)
设置模板路径
打开mysite5/mysite5/settings.py文件,在底部添加:
#template TEMPLATE_DIRS=( /home/fnngj/djpy/mysite5/online/templates )
使用功能
注册
先注册用户:
注册成功,提示“regist success!!”
登陆
执行登陆操作,通过读取浏览器cookie 来获取用户名
查看cookie
登陆成功
通过点击“退出”链接退出,再次访问http://127.0.0.1:8000/online/index/ 将不会显示用户名信息。
Win11系统下使用Django+Celery实现异步任务队列以及定时(周期)任务(2020年最新攻略) 首先明确一点,celery4.1+的官方文档已经详细说明,该版本之后不需要引入依赖 django-celery 这个库了,直接用 celery 本身就可以了,就在去年年初的一篇文章[python3.7.2+Django2.0.4 使用django-celery遇到的那些坑](https://v3u.cn/a_id_54),中提到的一些bug,在今年早已不复存在,所以技术更新频率越来越快,本文详细阐述用新版Celery(4.4.2)来实现。
Django用户认证系统 .权限管理 Django利用auth_permission表定义权限 Permission表的定义非常简单,只有三个属性: name:权限显示的名称,最多允许255个字符 content_type:关联ContentType(记录App与model的信息) codename:权限的名称编码,最多允许100个字
python的Web框架,Django模型系统二,模型属性,及数据库进阶查询 python的Web框架,Django模型系统二,模型属性,及数据库进阶查询 原始数据接上篇文章来操作。可能需要查看后才能懂。点击这里查看 1.常用的模型字段类型 官方文档:https://docs.djangoproject.com/en/2.1/ref/models/fields/#field-types 定义的模型中,类名对应的表名,类属性对应的表的字段,我们在上节内容有说过,可以查看。
django框架--视图系统 一、视图函数的理解 二、视图函数的定位 三、请求对象HttpRequest 四、响应对象HttpResponse 一、视图函数的理解 视图函数的作用是,对指定的url执行业务逻辑,视图函数将会作为model层和template层的桥梁,最主要的逻辑是操作数据库以及完成模板渲染前的上下文准备。
相关文章
- Django 使用 django-redis 作为缓存的正确用法,别忽略缓存的使用原则
- Django(75)django-rest-framework-simplejwt「建议收藏」
- Django(13)django时区问题
- Django(37)配置django日志[通俗易懂]
- DJango Uncaught ReferenceError: $ is not defined
- 基于Django+LayUI+HBase的文献数据挖掘系统(附源码)
- django 字段类型_access的数据库类型是
- Django-REST-framework 用户认证源码分析
- 【Django】聚合在Django的详细解析以及运用在企业级项目里的方法
- Django权限系统auth模块详解
- Django+Celery学习笔记3——django+celery+redis实现异步任务与定时任务
- Django登录页面优化
- Add a button/form/link to Django Admin(添加按钮、表单、链接到 django admin)
- Django 限制访问频率
- Django漏洞系列
- ImportError: Couldn't import Django.(pycharm)
- python-Django 高级特性-Django 中间件(二)
- python-Django 高级特性-Django 分页(一)
- python-Django 高级特性-Django 异步任务(二)
- Django REST Framework-基于Oauth2的身份验证(一)
- Django REST Framework-常用的权限类型
- Django REST Framework-分页(二)
- Django REST Framework-路由器(一)
- Django 01 Django中的路由系统详解编程语言
- Django的视图函数和路由系统中一些没有用过的小点详解编程语言
- 如何搜索查找并解决Django相关的问题