django简单实现注册登录模块
源码下载:https://files.cnblogs.com/files/hardykay/login.zip
新建项目(我使用pycharm开发,也可以使用如下命令建立项目 )
cmd命令行,前提需要安装django和配置系统环境变量,这里我就跳过了: django-admin startproject login 项目建好后通过cd 进入到项目目录执行以下命令: python manage.py startapp app01
需求分析
一个登录注册系统基本包含哪些功能呢?
1、首页
2、登录/注册页面
3、验证登录信息
4、验证注册信息
5、注销模块
概要设计
数据库设计ER图

urls.py文件
urlpatterns = [
path('admin/', admin.site.urls),
path('index/', views.index),
path('registerView/', views.registerView),
path('register/', views.register),
path('login/', views.login),
path('accounts/login/', views.logout),
]
setting.py文件
# 开发阶段放置项目自己的静态文件
STATICFILES_DIRS = (
os.path.join(BASE_DIR, 'statics'),
)
# 执行collectstatic命令后会将项目中的静态文件收集到该目录下面来(所以不应该在该目录下面放置自己的一些静态文件,因为会覆盖掉)
STATIC_ROOT = os.path.join(BASE_DIR, 'static')
数据库设计
1、models.py
from django.db import models # Create your models here.
class User(models.Model):
username = models.CharField(max_length=50)
email = models.CharField(max_length=60)
password = models.CharField(max_length=20) def __str__(self):
print(self.username)
2、建立数据库
# 1. 创建更改的文件
python manage.py makemigrations
# 2. 将生成的py文件应用到数据库
python manage.py migrate
views.py功能模块设计
from django.shortcuts import render,HttpResponseRedirect
from django.contrib import auth
from app01.myform import User as FUser
from app01.models import User
from django.contrib.auth.decorators import login_required
# Create your views here. def index(request):
user = request.session.get('user',False) return render(request,'app01/index.html',{'user':user})
#显示页面
def registerView(request):
user = request.session.get('user', False)
print(user)
if not user:
return render(request, 'app01/login.html')
else :
return HttpResponseRedirect('/index/') #注册
def register(request):
check = False
if request.method == 'POST':
form = FUser(request.POST)
if form.is_valid():
#print(form.cleaned_data)
user = User(**form.cleaned_data)
user.save()
check = True
return render(request, 'app01/immediate.html',{'check':check}) return HttpResponseRedirect('/index/') #登录
def login(request): user = request.POST['username']
password = request.POST['password']
result = User.objects.get(username=user,password=password) if not result:
return HttpResponseRedirect('/registerView/')
else :
request.session['user'] = user
return HttpResponseRedirect('/index/') #注销
def logout(request):
auth.logout(request)
return HttpResponseRedirect('/index/')
完整的views.py
首页模块设计(index函数)
def index(request):
user = request.session.get('user',False) return render(request,'app01/index.html',{'user':user})
后台代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
{% if not user %}
<a href="/registerView/">注册/登录</a>
{% else %}
您已经登录<a href="/accounts/login/">注销</a>
{% endif %}
</body>
</html>
前台代码
前后台是一起的,这里用了两个系统提供的功能模块:1、user = request.session.get('user',False)。2、return render(request,'app01/index.html',{'user':user})
1的作用是去键为user的session值,如果不存在则返回False,2的作用是将变量的值写入到模板,第二个参数是模板路径,第三个参数是需要渲染的字典。
登录/注册显示页面
def registerView(request):
user = request.session.get('user', False)
print(user)
if not user:
return render(request, 'app01/login.html')
else :
return HttpResponseRedirect('/index/')
后台代码
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<link href="/static/css/style.css" rel='stylesheet' type='text/css' />
<meta name="viewport" content="width=device-width, initial-scale=1">
<script type="application/x-javascript"> addEventListener("load", function() { setTimeout(hideURLbar, 0); }, false); function hideURLbar(){ window.scrollTo(0,1); } </script>
<!--webfonts-->
<!--//webfonts-->
</head>
<body>
<div class="main">
<div class="header" >
<h1>Login or Create a Free Account!</h1>
</div>
<p>Lorem iopsum dolor sit amit,consetetur sadipscing eliter,sed diam voluptua.At vero eso et accusam et justo duo dolores et ea rebum. </p>
<form action="/register/" method="POST">
<ul class="left-form">
<h2>New Account:</h2>
<li>
<input type="text" name="username" placeholder="Username" required/>
<a href="#" class="icon ticker"> </a>
<div class="clear"> </div>
</li>
{% csrf_token %}
<li>
<input type="text" name="email" placeholder="Email" required/>
<a href="#" class="icon ticker"> </a>
<div class="clear"> </div>
</li>
<li>
<input type="password" name="password" placeholder="password" required/>
<a href="#" class="icon into"> </a>
<div class="clear"> </div>
</li>
<li>
<input type="password" placeholder="password" required/>
<a href="#" class="icon into"> </a>
<div class="clear"> </div>
</li>
<label class="checkbox"><input type="checkbox" name="checkbox" checked=""><i> </i>Please inform me of upcoming w3layouts, Promotions and news</label>
<input type="submit" onClick="myFunction()" value="Create Account">
<div class="clear"> </div>
</ul>
</form>
<form action="/login/" method="post">
<ul class="right-form">
{% csrf_token %}
<h3>Login:</h3>
<div>
<li><input type="text" name="username" placeholder="Username" required/></li>
<li> <input type="password" name="password" placeholder="Password" required/></li>
<h4>I forgot my Password!</h4>
<input type="submit" onClick="myFunction()" value="Login" >
</div>
<div class="clear"> </div>
</ul>
<div class="clear"> </div> </form> </div>
<!-----start-copyright---->
<div class="copy-right">
<p>Template 2014. More Templates <a href="http://www.cssmoban.com/" target="_blank" title="模板之家">模板之家</a> - Collect from <a href="http://www.cssmoban.com/" title="网页模板" target="_blank">网页模板</a></p>
</div>
<!-----//end-copyright----> </body>
</html>
前台代码
验证注册信息模块
1、建立form系统验证
from django import forms class User(forms.Form):
username = forms.CharField(max_length=50)
email = forms.CharField(max_length=60)
password = forms.CharField(max_length=20)
myform.py
2、后台代码
def register(request):
check = False
if request.method == 'POST':
form = FUser(request.POST)
if form.is_valid():
#print(form.cleaned_data)
user = User(**form.cleaned_data)
user.save()
check = True
return render(request, 'app01/immediate.html',{'check':check}) return HttpResponseRedirect('/index/')
验证登录信息模块
def login(request):
user = request.POST['username']
password = request.POST['password']
result = User.objects.get(username=user,password=password)
if not result:
return HttpResponseRedirect('/registerView/')
else :
request.session['user'] = user
return HttpResponseRedirect('/index/')
注销
def logout(request):
auth.logout(request)
return HttpResponseRedirect('/index/')
django简单实现注册登录模块的更多相关文章
- Node.js基于Express框架搭建一个简单的注册登录Web功能
这个小应用使用到了node.js bootstrap express 以及数据库的操作 :使用mongoose对象模型来操作 mongodb 如果没了解过的可以先去基本了解一下相关概念~ 首先注 ...
- 详细讲解:使用tp3.2.3完成简单的注册登录功能
使用3.2.3进行了一个简单不过的注册登录功能,界面介绍: 1.注册: 2.登录: 3.登录成功后: 没错,就是简单的让你特别容易上手,上面运用到的知识有: (1)自动验证.自动完成 (2)sessi ...
- 从微信小程序到鸿蒙js开发【08】——表单组件&注册登录模块
目录: 1.登录模块 2.注册模块 3.系列文章导读 牛年将至,祝大家行行无bug,页页so easy- 在微信小程序中,提供了form组件,可以将input.picker.slider.button ...
- 关于Django auth注册登录模块的具体使用
from django.urls import path from . import views urlpatterns = [ #主页,用来显示类别等其他数据 path('',views.index ...
- node.js(node.js+mongoose小案例)_实现简单的注册登录退出
一.前言 通过node.js基本知识对node.js基本知识的一个简单应用 1.注册 2.登录 3.退出 二.基本内容 1.项目结构搭建如图所示 2.这个小案列中用到了art-template子模板以 ...
- ASP.NET会员注册登录模块(MD5加密,Parameters防止SQL注入,判断是否注册)
MD5加密,Parameters防止SQL注入: protected void btnLog_Click(object sender, EventArgs e) { //获取验 ...
- JAVAWEB 项目注册登录模块问题总结
tomcat: 假如tomcat服务器启动出现错误,那就可能是servlet或代码的原因 tomcat服务器出现不能访问页面的情况,可以在eclipse tomcat服务器设置里设置为共享服务器模式 ...
- Django:使用django自带的登录模块登录后会默认登录到 /accounts/profile 下的问题
django settings中LOGIN_REDIRECT_URL默认重定向到/accounts/profile下,可通过配置修改
- django 简单会议室预约(4)
基本的配置已经完成了,来看看最重要的views.py 先看看简单的注册登录功能,在django里有一个专门的模块用来验证用户信息 :所以只需要调用就好了: #-*-coding:utf-8 -*- f ...
随机推荐
- Java并发编程:进程的创建
Java并发编程:进程的创建 */--> code {color: #FF0000} pre.src {background-color: #002b36; color: #839496;} J ...
- sql插入语句笔记
使用INSERT插入数据行 [一次插入一行数据] 全写: INSERT INTO renshi (name, sex, age ,tel) VALUES ('胡大姐','女','35','13 ...
- 2. ZooKeeper基础
1. ZooKeeper的特性 ZooKeeper的特性主要从会话.数据节点,版本,Watcher,ACL权限控制,集群角色这些部分来了解,其中需要重点掌握的数据节点与Watcher 1.1 会话 客 ...
- Nexus搭建Maven私服中央仓库
一.概述 1.概要 现在的项目基本都是用Maven来管理工程,这样一来在公司内容搭建一个私服就非常有必要了,这样一来可以管理公司内部用的JAR包,也可以管理第三方的各种JAR来,以免每次都要从外网的仓 ...
- 注意!黑客可以通过CSS3功能攻击浏览器
随着通过HTML5和CSS3引入的惊人数量的功能,浏览器的攻击面也相应增长.因此,这些功能之间的交互可能会导致意外行为影响用户的安全,这并不奇怪.在这篇文章中,中国知名黑客安全组织东方联盟描述了这样一 ...
- Linux批量新建文件夹(大括号表达式的应用)
如果想要批量新建文件夹来存放照片,按照年份和月份,格式为YYYY-MM.可以使用下面命令批量新建: mkdir {2007..2009}-{01..12} 结果如下: 2007-01 2007-07 ...
- nyoj 78:圈水池 【凸包入门】
题目链接 将所有点按从左至右顺序排序,然后将所有点先从左到右扫描再从右到左扫描,逐渐将凸包轮廓“勾勒”出来 (凸包轮廓满足,轮廓上连续的三个点按先后顺序给出的话呈逆时针方向) 最后删去一个重复的起(终 ...
- vue 全局 js 方法
1.新增 getCurrentDataType.js 文件 import cookieUtils from '@/config/cookieUtils' function getCurrentData ...
- JavaScript的MD5加密
1.首先要到http://pajhome.org.uk/crypt/md5/下载js文件. 2.在页面文件中添加: <script type="text/javascript" ...
- boost Filesystem
The library Boost.Filesystem makes it easy to work with files and directories. Paths Paths can be bu ...