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表单 写登陆注册的更多相关文章

  1. django 基于form表单上传文件和基于ajax上传文件

    一.基于form表单上传文件 1.html里是有一个input type="file" 和 ‘submit’的标签 2.vies.py def fileupload(request ...

  2. Django框架form表单配合ajax注册

    总结一下,其实form组件的主要功能如下: 生成页面可用的HTML标签 对用户提交的数据进行校验 保留上次输入内容 下面是写的登录页面的实例 1:views视图中的代码 # 注册页面 def regi ...

  3. 基于form表单submit提交不跳转

    方法一:target <html> <body> <form action="" method="post" target=&qu ...

  4. 基于Spring MVC实现基于form表单上传Excel文件,批量导入数据

    在pom.xml中引入: <!--处理2003 excel--> <dependency> <groupId>org.apache.poi</groupId& ...

  5. 基于form表单的极验滑动验证小案例

    01.目录展示 02.url.py urlpatterns = [ path('admin/', admin.site.urls), path('login/',views.login), path( ...

  6. Laravel使用artisan快速实现表单的登陆注册

    1. 开发环境 macOS Mojave 10.14.6 XAMPP 5.6.38 Laravel 5.2 2. 在终端,先进入到项目根目录并执行执行命令 php artisan make:auth ...

  7. 基于Spring3 MVC实现基于form表单文件上传

    http://blog.csdn.net/jia20003/article/details/8474374/

  8. python自动化开发-[第二十天]-form表单,CBV和FBV,序列化

    1.CBV和FBV的用法 2.序列化用法 3.form表单 一.CBV和FBV 1.cbv是 class based view(基于类),fbv是function based view(基于函数) 2 ...

  9. 前端-form表单与CSS

    目录 form表单 表单属性 label标签 input标签 select 下拉框标签 textarea多行文本 提交 Flask 结合form表单 初探 CSS介绍以及基本选择器 基本选择器 组合选 ...

随机推荐

  1. 如何发布自己的node模块

    一.注册自己的npm账户 在 npm 官网 https://www.npmjs.org 申请一个账号,并且进行必要的验证,需要填写用户名.密码和邮箱.并且注册成功后会向邮箱发一封邮件,需要进行验证. ...

  2. java将所有的字符串转换为大写或小写

    public class DaXie { public static void main(String[] args) { /**将所有的字符串转换成大写或小写字母并打印出来*/ String str ...

  3. 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 ...

  4. nopcommerce 4.1 学习2 -插件之挂件

    先了解下nop4.1的一些插件有哪些类型: 1.支付插件   Nop.Plugin.Payments.PayPalStandard  Nop.Plugin.Payments.CheckMoneyOrd ...

  5. sql多表查询(单表查询略过)

    表library: 表borrow: 表reader: 1.等值连接:(常用) 原理:将多张表组合成一个逻辑大表,即字段相加记录相乘(笛卡尔积). 语法:select * from 表A,表B whe ...

  6. kolla-ansible配置cinder 的ceph的多种后端存储池【转】

    在实际的使用中,openstack后端采用ceph存储,存储磁盘类型有SATA和SSD,这里如果想基于存储驱动器提供多种云硬盘类型,可以基于下面的配置完成 点击查看配置详情

  7. JavaScript之Math

    1. Math Math是js的内置函数,无需创建,把Math作为对象使用就可以调用其属性和方法. 2.Date    2.1 日期对象创建 var now = new Date ( ); 含参数时表 ...

  8. less 查看日志

    上下键,空格下一页,字母B上一页  ,字母Q退出,n(小写字母n)上一个关键字位置N(大写字母N)下一个关键词位置] 二.查找某个时间段的日志:比如查询2018-08-15 10:37:32到2018 ...

  9. FreeSWITCH部署与功能配置

    一.FreeSWITCH服务部署 1.wget http://www.freeswitch.org.cn/Makefile && make install 2.cd freeswitc ...

  10. Shiro 整合SpringMVC 并实现权限管理,登录和注销

    Shiro 整合SpringMVC 并且实现权限管理,登录和注销 Apache Shiro是Java的一个安全框架.目前,使用Apache Shiro的人越来越多,因为它相当简单,对比Spring S ...