Django认证系统实现的web页面
结合数据库、ajax、js、Djangoform表单和认证系统的web页面
一:数据模块
扩展了Django中的user表,增加了自定义的字段
from django.db import models
from django.contrib.auth.models import AbstractUser
# Create your models here.
class UserInfo(AbstractUser):
phone = models.CharField(max_length=11)
gender = models.CharField(max_length=2)
二:路由系统
from django.conf.urls import url
from django.contrib import admin
from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^register/',views.register),
url(r'^login/',views.login_view),
url(r'^home/',views.home),
url(r'^logout/',views.logout_view),
url(r'^modify_pwd/',views.modify_pwd),
url(r'^$',views.home),
]
三:视图系统
from django.shortcuts import render, redirect
from django.contrib.auth.decorators import login_required
from django.http import JsonResponse
from django.contrib.auth import authenticate, login,logout
from app01 import forms
from app01.models import UserInfo # Create your views here.
def register(request):
form_obj = forms.Reg_form()
if request.method == 'POST':
form_obj = forms.Reg_form(request.POST)
if form_obj.is_valid():
info_dic = form_obj.cleaned_data
sex_dic = {'':'男','':'女','':'保密'}
info_dic['gender']=sex_dic[info_dic['gender']] UserInfo.objects.create_user(
username=info_dic['username'],
password = info_dic['pwd'],
gender=info_dic['gender'],
phone =info_dic['phone']
)
return redirect('/login/')
return render(request, "register.html",{'form_obj':form_obj}) def login_view(request):
if request.method == 'POST':
username = request.POST.get('username')
pwd = request.POST.get('pwd')
user = authenticate(username=username, password=pwd)
if user:
login(request, user)
data = {'code':1}
else:
data = {'code': 0,'msg':'用户名或密码错误'}
return JsonResponse(data)
return render(request, 'login.html') @login_required
def logout_view(request):
logout(request)
return redirect('/login/') @login_required
def home(request):
user_id = request.session['_auth_user_id']
use_obj = request.user
return render(request,'home.html',{'user':use_obj}) @login_required
def modify_pwd(request):
if request.method == 'POST':
old_pwd = request.POST.get('old_pwd')
pwd = request.POST.get('pwd')
re_pwd = request.POST.get('re_pwd')
user_obj = request.user
if user_obj.check_password(old_pwd):
if re_pwd == pwd:
user_obj.set_password(pwd)
user_obj.save()
data = {'code': 1}
else:
data = {'code': 0, 'msg': '两次输入密码不一致'}
else:
data = {'code': 0, 'msg': '原始密码输入错误'}
return JsonResponse(data)
return render(request,'modify_pwd.html')
四:form表单
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
# Author:YiJun
from django import forms
from app01 import models
from django.forms import widgets
from django.core.exceptions import ValidationError # 导入异常
import re # Create your views here.
class Reg_form(forms.Form):
# 用户名表单
username = forms.CharField(
min_length=4,
label="设置用户名",
error_messages={
"required": "不能为空",
"invalid": "格式错误",
"min_length": "用户名最少4个字符"
},
widget=widgets.TextInput(
attrs={
'class': "form-control",
'placeholder': '用户名'
})
)
# 用户密码设置表单
pwd = forms.CharField(
min_length=6,
label="设置密码",
widget=forms.widgets.PasswordInput(
attrs={
'class': 'form-control',
'placeholder': '密码'},
render_value=True,
),
error_messages={
"required": "不能为空",
"invalid": "格式错误",
"min_length": "密码至少6位" }
)
# 用户密码确认表单
r_pwd = forms.CharField(
min_length=6,
label="确认密码",
widget=forms.widgets.PasswordInput(
attrs={
'class': 'form-control',
'placeholder': '确认密码'},
render_value=True,
),
error_messages={
"required": "不能为空",
"invalid": "格式错误",
"min_length": "密码至少6位" }
)
# 用户性别选择表单
gender = forms.ChoiceField(
choices=((1, "男"), (2, "女"), (3, "保密")),
label="性别",
initial=3,
widget=forms.widgets.RadioSelect
)
# 用户手机号码表单
phone = forms.CharField(
label="手机号码",
max_length=11,
min_length=11,
error_messages={
"required": "不能为空",
"invalid": "格式错误",
"min_length": "手机号码至少11位",
"max_length": "手机号码最多11位",
},
widget=widgets.TextInput(attrs={'class': "form-control",'placeholder': '手机号码'})
) def clean_phone(self):
value = self.cleaned_data['phone']
expression = re.compile('^1[3589][0-9]{9}')
if not expression.search(value).group():
raise ValidationError('请输入正确的手机号码')
else:
return value
def clean_username(self):
value = self.cleaned_data['username']
if models.UserInfo.objects.filter(username=value):
raise ValidationError('用户名已经注册')
else:
return value def clean(self):
pwd = self.cleaned_data.get("pwd")
r_pwd = self.cleaned_data.get("r_pwd")
if pwd != r_pwd:
self.add_error("r_pwd", "两次输入的密码不一致!")
# 两次输入的密码不一致
raise ValidationError("两次输入的密码不一致!")
else:
self.cleaned_data.pop('r_pwd')
return self.cleaned_data
五:模板系统
注册页面
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport"
content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<link rel="stylesheet" href="/static/bootstrap-3.3.7/css/bootstrap.min.css">
<title>Document</title>
</head>
<body>
<div class="container">
<div class="row" style="margin-top: 50px">
<div class="panel panel-primary"> <div class="panel-heading"><h4>用户详细信息</h4></div>
<div class="panel-body"> </div> <!-- Table -->
<div class="table-responsive">
<table class="table table-bordered">
<thead>
<tr>
<th>#</th>
<th>用户名</th>
<th>手机号码</th>
<th>上次登陆时间</th>
<th>注册时间</th>
<th>用户性别</th>
</tr>
</thead>
<tbody>
<tr>
<th scope="row">1</th>
<td>{{ user.username }}</td>
<td>{{ user.phone }}</td>
<td>{{ user.last_login|date:'Y-m-d H:i:s' }}</td>
<td>{{ user.date_joined|date:'Y-m-d H:i:s' }}</td>
<td>{{ user.gender }}</td>
</tr>
</tbody>
</table>
</div>
</div>
<div style="margin-top: 20px">
<a class="btn btn-info " href="/modify_pwd/">修改密码</a>
<a class="btn btn-danger pull-right" href="/logout/">注销</a>
</div>
</div>
</div>
<script src="/static/jquery-3.3.1.min.js"></script>
<script src="/static/bootstrap-3.3.7/js/bootstrap.min.js"></script> </body>
</html>
home.html
Django认证系统实现的web页面的更多相关文章
- django 认证系统--3
WEB request中的认证 django使用sessions和middleware和reqeust对象联系在一起 它们通过给每一个reqeust请求添加一个request.user属性来代表当前用 ...
- Django认证系统并不鸡肋反而很重要
在使用django-admin startproject创建项目后,Django就默认安装了一个采用session实现的认证系统.这是Django相比于其他框架的一大特点:自带认证系统,开箱即用.有人 ...
- Django认证系统auth认证
使用Django认证系统auth认证 auth认证系统可以处理范围非常广泛的任务,且具有一套细致的密码和权限实现.对于需要与默认配置不同需求的项目,Django支持扩展和自定义认证;会将用户信息写入到 ...
- django认证系统 Authentication
Django自带一个用户认证系统,用于处理用户账户.群组.许可和基于cookie的用户会话. Django的认证系统包含了身份验证和权限管理两部分.简单地说,身份验证用于核实某个用户是否合法,权限管理 ...
- 自定义Django认证系统的技术方案
Django已经提供了开箱即用的认证系统,但是可能并不满足我们的个性化需求.自定义认证系统需要知道哪些地方可以扩展,哪些地方可以替换.本文就来介绍自定义Django认证系统的相关技术细节. 自定义认证 ...
- django 认证系统--2
使用django的认证系统 User 对象 User是认证系统的核心.典型代表是用户和你的站点进行交互还有限制访问.注册用户等等.django认证框架中,只存在一个User类,像'superuser' ...
- django 认证系统--1
django的认证系统提供认证和授权两种功能 认证系统包括如下部分: 1.Users 2.Permissions 主要是以 YES/NO 的形式反映一个用户是否能够做某事 3.Groups:就是对多个 ...
- django认证系统-user对象(创建,改密,认证)
User对象 User对象是认证系统的核心.它们通常表示与你的站点进行交互的用户,并用于启用限制访问.注册用户信息和关联内容给创建者等.在Django的认证框架中只存在一种类型的用户,因此诸如'sup ...
- Django认证系统
一.cooie与session 1.1 cookie与session cooie不属于http协议范围,由于http协议无法保持状态,但实际情况,我们却又要保持状态,因此cookie就是在这样的一个场 ...
随机推荐
- mysql按日期分组统计数据
最近在做一个招聘网时,需要显示一个月内企业招聘信息的发布数量,按日期分组统计,刚开始是直接从源数据库表里面进行group by,但这样子就出现日期不连续的问题了,我想要的效果是,若当天没有数据,则显示 ...
- [转贴] IPSEC From 知乎
作者:埃文科技链接:https://zhuanlan.zhihu.com/p/44874772来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 认识IPSec IPSec ...
- SpringBoot(七)_统一异常处理
我感觉看了这节课,给我的思考还是很多的,感觉受益良多.废话不多说,一起学习. 统一的 外层结构返回 这样利于代码看着也规范,前端处理也统一 # 错误返回 { "code": 1, ...
- mybatis的mapper参数传递
简单参数传递 简单参数传递是指: 传递单个基本类型参数,数字类型.String 传递多个基本类型参数 parameterType 属性可以省略: 传递单个基本类型参数 SQL语句中参数的引用名称并不 ...
- php三种方法从控制结构或脚本中跳出
PHP中,如果希望停止一段代码,根据需要达到的效果不同,可以有三种方法实现: 1. break: 如果在循环中使用了break语句,脚本就会从循环体后面的第一条语句开始执行: 2. continue: ...
- BZOJ3289 Mato的文件管理(莫队+树状数组)
这个做法非常显然. #include<iostream> #include<cstdio> #include<cmath> #include<cstdlib& ...
- 题解 P2026 【求一次函数解析式】
高中方式轻松解决这个模拟题. 首先我们了解斜率的简单求法: \[k= {y2-y1 \over x2-x1}{=}{\Delta y \over \Delta x}\] 然后我们了解到让我们求解一次函 ...
- Multi-class Classification相关
标签(空格分隔): 毕业论文 (OS: 最近在做关于多类分类的综述,但是搜索出来好多方向搞得自己云里雾里的,好吧,又是在下孤陋寡闻了.还是那句话,不知道不可怕,但一直不知道就很尴尬了.) one-cl ...
- 【Cf #502 F】The Neutral Zone
本题把$log$化简之后求得就是每个质数$f$前的系数,求系数并不难,难点在于求出所有的质数. 由于空间限制相当苛刻,$3e8$的$bitset$的内存超限,我们考虑所有的除了$2$和$3$以外的质数 ...
- [Codeforces Gym] 100162B Circle of Stones
题意: 桌子上有 n 个石头围成一个环.每个石头都有一种颜色.每种颜色可以由小写英文字母表示.如果每一对相邻的石头都是不同颜色的,则称这 n 个石头构成的环是美丽的.现在,你可以从这 n 个石头中拿走 ...