基于form表单 写登陆注册
urls
urlpatterns = [ url(r'^admin/', admin.site.urls), # 登录界面url(r'^login/$', views.login,name='login'), # 注册界面url(r'^reg/$', views.reg,name='reg'),]
forms
from django import forms
# 注册 formclass RegForm(forms.ModelForm):
username= forms.EmailField(label='用户名', error_messages={'required':'邮箱不能为空', 'invalid':'邮箱格式错误'}, ) password = forms.CharField( label='密码', min_length=8, strip=True, widget=forms.widgets.PasswordInput(), validators=[RegexValidator(r'^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{8,16}$', '输入8-16位密码数字与字母')], error_messages={ 'min_length': '用户名不小于8', 'required': '不能为空' } ) re_password = forms.CharField( label='确认密码', min_length=8, strip=True, widget=forms.widgets.PasswordInput(), validators=[RegexValidator(r'^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{8,16}$', '输入8-16位密码数字与字母')], error_messages={
'required': '不能为空' } ) name = forms.CharField( label='姓名', strip=True, validators=[check_name], error_messages={
'required': '不能为空' }
) # 配置文件 用class Meta class Meta: # 继承表格 model=models.UserProfile # 字段顺序 1.fields = '__all__' 所有字段 2. exclude = [''] 除了列表里的 fields=['username','password', 're_password', 'name', 'department'] # 指定的字段 # 设置字段名 labels={'username':'用户名','department': '部门'}
# 全局钩子判断2次密码一直不 用户存在没def clean(self): pwd=self.cleaned_data.get('password') re_pwd=self.cleaned_data.get('re_password') username=self.cleaned_data.get('username') user_model = list(models.UserProfile.objects.all().values_list('username')) for i in user_model: if username in i: self.add_error('username', '用户名已存在') raise ValidationError('用户名已存在') if pwd == re_pwd: return self.cleaned_data self.add_error('re_pwd','两次密码不一致') raise ValidationError('两次密码不一致')
views
from crm.forms import RegFormfrom django.contrib import auth
# 注册界面def reg(request): form_obj=RegForm() if request.method=='POST': form_obj = RegForm(request.POST) if form_obj.is_valid(): # 获取注册信息方法一 # form_obj.cleaned_data.pop('re_password') # UserProfile.objects.create_user(**form_obj.cleaned_data)
# 获取注册信息方法二 obj=form_obj.save() obj.set_password(obj.password) obj.save() return redirect('/crm/login/') return render(request,'reg.html',{'a':form_obj})
#登录
def login(request): err_msg = '' if request.method == 'POST': username = request.POST.get('username') password = request.POST.get('password') obj = auth.authenticate(request, username=username, password=password) if obj: return redirect('/index/') err_msg = '用户名或密码错误' return render(request, 'login.html', {'err_msg': err_msg})
html
<h1>注册</h1>
<form class="form-horizontal" action="" method="post" novalidate> {% csrf_token %} <div class="form-group {% if a.username.errors %}has-error {% endif %}"> <label for="{{ a.username.id_for_label }}" class="col-sm-5 control-label">{{ a.username.label }}</label> <div class="col-sm-3">{{ a.username}} <span id="helpBlock2" class="help-block">{{ a.username.errors.0}}</span> </div> </div>
<div class="form-group {% if a.password.errors %}has-error {% endif %}"> <label for="{{ a.password.id_for_label }}" class="col-sm-5 control-label">{{ a.password.label }}</label> <div class="col-sm-3">{{ a.password }} <span id="helpBlock2" class="help-block">{{ a.password.errors.0}}</span> </div> </div>
<div class="form-group {% if a.re_password.errors %}has-error {% endif %}"> <label for="{{ a.re_password.id_for_label }}" class="col-sm-5 control-label">{{ a.re_password.label }}</label> <div class="col-sm-3">{{ a.re_password }} <span id="helpBlock2" class="help-block">{{ a.re_password.errors.0}}</span> </div> </div>
<div class="col-sm-offset-5 col-sm-3"> <button type="submit" class="btn btn-primary btn-block ">提交</button> </div> </div> </form> <h1>登录</h1>
<form action="" method="post"> {% csrf_token %} <div class="login-top"> 登录</div><div class="login-center clearfix"> <div class="login-center-img"><img src="{% static 'imgs/name.png' %}"></div> <div class="login-center-input"> <input type="text" name="username" value="admin" placeholder="请输入您的用户名" onfocus="this.placeholder=''" onblur="this.placeholder='请输入您的用户名'"> <div class="login-center-input-text">用户名</div> </div></div>
<div class="login-center clearfix"> <div class="login-center-img"><img src="{% static 'imgs/password.png' %}"></div> <div class="login-center-input"> <input type="password" name="password" value="" placeholder="请输入您的密码" onfocus="this.placeholder=''" onblur="this.placeholder='请输入您的密码'"> <div class="login-center-input-text">密码</div> </div></div>
<div style="text-align: center"> <button class="login-button">登录</button></div></form>
基于form表单 写登陆注册的更多相关文章
- django 基于form表单上传文件和基于ajax上传文件
一.基于form表单上传文件 1.html里是有一个input type="file" 和 ‘submit’的标签 2.vies.py def fileupload(request ...
- Django框架form表单配合ajax注册
总结一下,其实form组件的主要功能如下: 生成页面可用的HTML标签 对用户提交的数据进行校验 保留上次输入内容 下面是写的登录页面的实例 1:views视图中的代码 # 注册页面 def regi ...
- 基于form表单submit提交不跳转
方法一:target <html> <body> <form action="" method="post" target=&qu ...
- 基于Spring MVC实现基于form表单上传Excel文件,批量导入数据
在pom.xml中引入: <!--处理2003 excel--> <dependency> <groupId>org.apache.poi</groupId& ...
- 基于form表单的极验滑动验证小案例
01.目录展示 02.url.py urlpatterns = [ path('admin/', admin.site.urls), path('login/',views.login), path( ...
- Laravel使用artisan快速实现表单的登陆注册
1. 开发环境 macOS Mojave 10.14.6 XAMPP 5.6.38 Laravel 5.2 2. 在终端,先进入到项目根目录并执行执行命令 php artisan make:auth ...
- 基于Spring3 MVC实现基于form表单文件上传
http://blog.csdn.net/jia20003/article/details/8474374/
- python自动化开发-[第二十天]-form表单,CBV和FBV,序列化
1.CBV和FBV的用法 2.序列化用法 3.form表单 一.CBV和FBV 1.cbv是 class based view(基于类),fbv是function based view(基于函数) 2 ...
- 前端-form表单与CSS
目录 form表单 表单属性 label标签 input标签 select 下拉框标签 textarea多行文本 提交 Flask 结合form表单 初探 CSS介绍以及基本选择器 基本选择器 组合选 ...
随机推荐
- 如何发布自己的node模块
一.注册自己的npm账户 在 npm 官网 https://www.npmjs.org 申请一个账号,并且进行必要的验证,需要填写用户名.密码和邮箱.并且注册成功后会向邮箱发一封邮件,需要进行验证. ...
- java将所有的字符串转换为大写或小写
public class DaXie { public static void main(String[] args) { /**将所有的字符串转换成大写或小写字母并打印出来*/ String str ...
- Convert BST to Greater Tree
Given a Binary Search Tree (BST), convert it to a Greater Tree such that every key of the original B ...
- nopcommerce 4.1 学习2 -插件之挂件
先了解下nop4.1的一些插件有哪些类型: 1.支付插件 Nop.Plugin.Payments.PayPalStandard Nop.Plugin.Payments.CheckMoneyOrd ...
- sql多表查询(单表查询略过)
表library: 表borrow: 表reader: 1.等值连接:(常用) 原理:将多张表组合成一个逻辑大表,即字段相加记录相乘(笛卡尔积). 语法:select * from 表A,表B whe ...
- kolla-ansible配置cinder 的ceph的多种后端存储池【转】
在实际的使用中,openstack后端采用ceph存储,存储磁盘类型有SATA和SSD,这里如果想基于存储驱动器提供多种云硬盘类型,可以基于下面的配置完成 点击查看配置详情
- JavaScript之Math
1. Math Math是js的内置函数,无需创建,把Math作为对象使用就可以调用其属性和方法. 2.Date 2.1 日期对象创建 var now = new Date ( ); 含参数时表 ...
- less 查看日志
上下键,空格下一页,字母B上一页 ,字母Q退出,n(小写字母n)上一个关键字位置N(大写字母N)下一个关键词位置] 二.查找某个时间段的日志:比如查询2018-08-15 10:37:32到2018 ...
- FreeSWITCH部署与功能配置
一.FreeSWITCH服务部署 1.wget http://www.freeswitch.org.cn/Makefile && make install 2.cd freeswitc ...
- Shiro 整合SpringMVC 并实现权限管理,登录和注销
Shiro 整合SpringMVC 并且实现权限管理,登录和注销 Apache Shiro是Java的一个安全框架.目前,使用Apache Shiro的人越来越多,因为它相当简单,对比Spring S ...