当前位置: 首页 > 编程日记 > 正文

用Django内置form组件实现注册

HTML页面代码块:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5 
 6     <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.min.css">
 7     <title>首页</title>
 8 </head>
 9 <body>
10 
11 <div class="container">
12     <div class="row">
13         <div class="col-md-6 col-md-offset-3">
14             <form action="/index/" method="post" novalidate>
15                 {% csrf_token %}
16                 <div class="form-group {% if reg.user.errors.0 %} has-error {% endif %}">
17                     {{ reg.user.label }}
18                     {{ reg.user }}
19                     <span class="help-block" id="s1">{{ reg.user.errors.0 }}</span>
20                 </div>
21                 <div class="form-group {% if reg.psd.errors.0 %} has-error {% endif %}">
22                     {{ reg.psd.label }}
23                     {{ reg.psd }}
24                     <span class="help-block">{{ reg.psd.errors.0 }}</span>
25                 </div>
26                 <div class="form-group {% if reg.re_pwd.errors.0 %} has-error {% endif %}">
27                     {{ reg.re_pwd.label }}
28                     {{ reg.re_pwd }}
29                     <span class="help-block">{{ reg.re_pwd.errors.0 }}</span>
30                 </div>
31                 <div class="form-group {% if reg.email.errors.0 %} has-error {% endif %}">
32                     {{ reg.email.label }}
33                     {{ reg.email }}
34                     <span class="help-block">{{ reg.email.errors.0 }}</span>
35                 </div>
36                 <div class="form-group {% if reg.mobile.errors.0 %} has-error {% endif %}">
37                     {{ reg.mobile.label }}
38                     {{ reg.mobile }}
39                     <span class="help-block">{{ reg.mobile.errors.0 }}</span>
40                 </div>
41 
42                 <div class="form-group {% if reg.city.errors.0 %} has-error {% endif %}">
43                     {{ reg.city.label }}
44                     {{ reg.city }}
45                     <span class="help-block">{{ reg.city.errors.0 }}</span>
46                 </div>
47                 <div class="form-group">
48                     <button type="submit" class="btn btn-success">登录</button>
49                 </div>
50 
51             </form>
52         </div>
53     </div>
54 
55 </div>
56 
57 <script src="/static/jquery-3.3.1.min.js"></script>
58 <script src="/static/csrf_ajax.js"></script>
59 <script src="/static/bootstrap/js/bootstrap.min.js"></script>
60 <script>
61     $("#id_user").on ('input',function () {
62         var user=$(this).val();
63         $("#s1").text('');
64         $.ajax({
65             url:'/check/',
66             type:'POST',
67             data:{"user":user},
68             datatype:'json',
69             success:function (arg) {
70                 if (arg){
71 
72                     $("#s1").text(arg).css("color", "red");
73 
74                 }
75 
76             }
77         })
78     })
79 </script>   
80 </body>
81 </html>

views代码块的逻辑处理:>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

 1 from django.shortcuts import render,redirect,HttpResponse
 2 
 3 # Create your views here.
 4 
 5 from appfind import models
 6 
 7 def check(request):
 8     if request.method=="POST":
 9         user=request.POST.get('user')
10         user_obj=models.UserInfo.objects.filter(user=user)
11         if user_obj:
12             msg='用户名已存在。请更换!'
13         else:
14             msg=''
15         return HttpResponse(msg)
16 
17 from django import forms
18 from django.forms import widgets
19 from django.core.validators import RegexValidator
20 from  django.core.exceptions import ValidationError
21 class RegForm(forms.Form):  #利用RegForm去生成HTML字段标签
22     user=forms.CharField(max_length=32,label='用户名',
23                          error_messages={"required": "该字段不能为空",},
24                          widget=widgets.TextInput(attrs={'class':'form-control'}))
25     psd=forms.CharField(label='密码',min_length=6,max_length=30,
26                         widget=widgets.PasswordInput(attrs={'class':'form-control'},render_value=True),
27                         error_messages={'min_length':'密码不能少于6位',
28                                         "max_length": "密码最长30位!",
29                                         "required": "该字段不能为空",})
30     re_pwd = forms.CharField(label='确认密码', min_length=6, max_length=30,
31                              widget=widgets.PasswordInput(attrs={'class': 'form-control'}, render_value=True),
32                              error_messages={'min_length': '密码不能少于6位',
33                                              "max_length": "密码最长30位!",
34                                              "required": "该字段不能为空", })
35     email=forms.EmailField( label="邮箱",
36                             widget=widgets.EmailInput(attrs={"class": "form-control"}),
37                             error_messages={
38                                 "required": "该字段不能为空",
39                             })
40     mobile = forms.CharField(label="手机",
41                              validators=[
42                                  RegexValidator(r'^[0-9]+$','手机号码必须是数字'),
43                                  RegexValidator(r'^1[3-8][0-9]{9}$','手机格式有误')
44                              ],
45                              widget=widgets.TextInput(attrs={"class": "form-control"}),
46                              error_messages={
47                                  "required": "该字段不能为空",
48                              })
49     def clean_user(self):  #clean_user  user 就是要检验的字段
50         value=self.cleaned_data.get('user')
51         if "独裁" in value:
52             raise ValidationError("不符合社会主义核心价值观!")
53         return value
54 
55     def clean(self):   #重写父类的clean方法
56         # 此时 通过检验的字段的数据都保存在 self.cleaned_data
57         psd=self.cleaned_data.get('psd')
58         re_pwd=self.cleaned_data.get('re_pwd')
59         if psd != re_pwd:
60             self.add_error('re_pwd',ValidationError('两次密码不一致'))
61             raise ValidationError('两次密码不一致')
62         return self.cleaned_data
63 
64     city=forms.ChoiceField(
65         choices=models.City.objects.all().values_list('id','name'),
66         label='城市',   
67         initial=1,
68         widget=forms.widgets.Select
69     )
70 
71     def __init__(self,*args,**kwargs):   #重写父类的__init__方法
72         super().__init__(*args,**kwargs)  #每次初始化加载插件就重新再数据库里取值
73         self.fields['city'].widget.choices=models.City.objects.all().values_list('id','name')
74 
75 def index(request):
76     regform=RegForm()           #实例化一个RegForm对象
77     if request.method=="POST":
78         regform = RegForm(request.POST)  #获取对象
79         if regform.is_valid():           #校验对象的所有字段
80             del regform.cleaned_data['re_pwd']     #删除部分用户表不需要存储的字段
81             del regform.cleaned_data['city']
82             models.UserInfo.objects.create(**regform.cleaned_data)  #数据库添加用户数据
83             return HttpResponse('恭喜,注册成功!')
84 
85     return render(request,'index.html',{'reg':regform})
86     #get请求直接把RegForm对象传给页面

转载于:https://www.cnblogs.com/wen-kang/p/9635332.html

相关文章:

Mac上搭建Nginx + rtmp

介绍 nginx是非常优秀的开源服务器&#xff0c;用它来做hls或者rtmp流媒体服务器是非常不错的选择&#xff0c;本人在网上整理了安装流程&#xff0c;分享给大家并且作备忘。 安装步骤 1.先安装brew&#xff1a; /usr/bin/ruby -e "$(curl -fsSL https://raw.githubuserco…

关于 ListBox 自动换行

网络上搜不到能用的信息&#xff0c;在此记录一下我的方案。 思路是通过数据模板&#xff0c;达到换行的目的&#xff0c;如下&#xff1a; 1 <ListBox.ItemTemplate> 2 <DataTemplate> 3 <TextBlock Text"{Binding}" TextWrapping"…

c语言链表找姓,急啊!!!求救了 C语言编一个链表,输出姓名和学号就好

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼#include#include#include#includetypedef struct Node{int data;struct Node *next;}AN;int data;AN *CreList(AN *head);AN *InsList(AN *head,int data);AN *DelList(AN *head,int data);void find(int value,AN *head);void De…

计算机审计 pdf,计算机审计第三章作业.pdf

1. 审计软件的审计实施阶段前&#xff0c;包括哪些内容&#xff1f;答&#xff1a; a. 项目管理b. 数据准备c. 审计准备2. 新建审计项目时&#xff0c;在“项目登记”界面里&#xff0c;在定义‘审计时限范围’时&#xff0c;可以创建多年度数据时间吗&#xff1f;答&#xff1…

c语言通讯录打电话,C语言实现简易通讯录 | 术与道的分享

#include #include #include #include #include #pragma warning (disable:4996)enum Contact //枚举变量{Quit, //默认为0&#xff0c;下面依次递增1Add, //1Delect, //2Select, //3Alter, //4Show, //5Empty, //6Sort //7};//打印菜单void menu(){printf("#############…

Excel向数据库插入数据和数据库向Excel导出数据

为了熟悉java里工作簿的相关知识点&#xff0c;所以找了“Excel向数据库插入数据和数据库向Excel导出数据”的功能来实现。 注意事项&#xff1a;1&#xff0c;mysql数据库&#xff1b; 2&#xff0c;需要导入的jar包有 jxl.jar&#xff0c;mysql-connector-java-5.1.22-bin.ja…

9.12学习内容

操作系统基础 操作系统是协调、控制、管理计算机硬件资源与软件资源的控制程序 为什么要用操作系统&#xff1f; 1.操作系统可以把复杂的操作简化给用户使用或者应用程序 2.可以让应用程序对计算机硬件竞争变的有序 一套完整的计算机分为&#xff1a;操作系统、应用程序、计算机…

xcode 8 重新支持插件

苹果出了Xcode8之后&#xff0c;就加了签名让之前的自定义插件无法继续的安装使用。想要重新使用插件的话只要用自己的签名覆盖苹果的签名即可。 1.创建自签名证书 钥匙串-》钥匙串访问-》证书助理-》创建证书... 名称&#xff1a;XcodeSigner(可以随便命名&#xff0c;后面要使…

pda找不到服务器,PDA连不上服务器常见问题分析.doc

PDA连不上服务器常见问题分析.docPDA连不上服务器常见问题分析请查看PDA的网络通不通&#xff0c;可以先检查WIFI/3G是否连接上网络&#xff0c;如果连接不上&#xff0c;点击PingToots工具&#xff0c;用"ping 服务器地址" 比如 ping 192.168.1.1 看和服务器网络通不…

android 运动管理,使用 MotionLayout 管理运动和微件动画

创建 MotionScene&#xff1a;在之前的 MotionLayout 示例中&#xff0c;app:layoutDescription 属性引用一个 MotionScene。MotionScene 是一个 XML 资源文件&#xff0c;其中包含相应布局的所有运动描述。为了将布局信息与运动描述分开&#xff0c;每个 MotionLayout 都引用一…

ios Carthage

使用CocoaPods来管理第三方框架很多人都知道&#xff0c;相对来说Carthage比较陌生&#xff0c;Carthage也是来管理第三方框架的&#xff0c;既然已经有了Cocoapods为什么还要有Carthage呢&#xff1f;使用Carthage有什么好处呢&#xff1a; 首先&#xff0c;CocoaPods默认会自…

计算机c1 c语言答题,全国计算机级考试二级C语言上机答题技巧.doc

全国计算机等级考试二级C语言上机答题技巧1&#xff0e;上机改错的试题中通常包含两个(或三个)错误需要修改。  2&#xff0e;试题中用"******found******/"来提示在下一行(或下面第二行)有错。  3&#xff0e;错误的性质基本分语法错和逻辑错两种&#xff0c;也…

springboot +element-axios跨域请求

1、初始化element项目   1.1&#xff1a;vue init webpage 项目名称 1.2&#xff1a;npm i element-ui -S 1.3&#xff1a;在main.js添加    import ElementUI from element-uiimport element-ui/lib/theme-chalk/index.cssVue.use(ElementUI) 2、添加axios跨域请求 在main…

Nginx 主要应用场景

一、反向代理 反向代理&#xff08;Reverse Proxy&#xff09;方式是指以代理服务器来接受internet上的连接请求&#xff0c;然后将请求转发给内部网络上的服务器&#xff0c;并将从服务器上得到的结果返回给internet上请求连接的客户端。 server { listen 80; …

ios .a和.framework

创建Aggregate来合并模拟器和真机通用的framework 然后在Build Phases下New Run Script Phase创建合并脚本&#xff1a; # Constants SF_TARGET_NAME${PROJECT_NAME} #自定义的用来存放最后合并的framework UNIVERSAL_OUTPUTFOLDER${BUILD_DIR}/${CONFIGURATION}-universal #IP…

android上下文关系,Android Context上下文的理解 Hua

8种机械键盘轴体对比本人程序员&#xff0c;要买一个写代码的键盘&#xff0c;请问红轴和茶轴怎么选&#xff1f;Context概念在安卓对象中&#xff0c;Context是经常使用的元素…但应该也是错误使用率最高的。你在加载资源、启动一个新的Activity、获取系统服务、获取内部文件(…

打开云服务器连不上网,云服务器怎么连接网络连接不上

traceroute(路由跟踪)通常&#xff0c;ping程序用于确定基本连接是否通&#xff0c;traceroute实用程序可用于确定目标打开终端&#xff0c;输入traceroute&#xff0c;点击回车即可可以检测主机和目标主机之间进行交互所经过的网关数量&#xff0c;由接受的数据包来得出结果。…

Pandas缺失数据

数据丢失(缺失)在现实生活中总是一个问题。 机器学习和数据挖掘等领域由于数据缺失导致的数据质量差&#xff0c;在模型预测的准确性上面临着严重的问题。 在这些领域&#xff0c;缺失值处理是使模型更加准确和有效的重点。 何时以及为什么数据丢失&#xff1f; 想象一下有一个…

android servlet 登陆,Android Studio+Servlet+MySql实现登录注册

一、Android 项目当中设置明文传输1、设置明文传输的xml2、引入上述创建的xmlandroid:networkSecurityConfig"xml/network_security_config"二、在MyEclipse当中创建Web项目1、创建项目引入MySQL的驱动包2、创建实体类Userpackage entity;public class User {private…

tomcat在服务器上改了8080的端口之后所带来的问题

因为与IIS的端口冲突&#xff0c;有人会在服务器上改tomcat的端口。但是tomcat在服务器上将端口8080改了之后&#xff0c;可能会导致所不熟的项目在访问时只能访问前面的域名&#xff0c;用户是使用时显示的域名看不到后面的后缀&#xff0c;比如aaa.com/aa&#xff0c;用户不论…

修改git的远程仓库命令

1. 修改命令 git remte origin set-url URL 2.先删后加 git remote rm origin git remote add origin gitgithub.com:Liutos/foobar.git 3. 直接修改config文件

c# 网站在服务器上第一次请求都需要耗时很久,最.net面试题目.doc

经典.net面试这些是C#ASP.NET数据库面试题&#xff0c;全部从网上收集而来&#xff0c;经整理而发表&#xff0c;希望给大家带来帮助&#xff0c;有错误的地方还请各位高手指出&#xff0c;在下倾听指教。1. 简述private、protected、public、internal 修饰符的访问权限。答. p…

动态语言的灵活性是把双刃剑 -- 以Python语言为例

本文有些零碎&#xff0c;总题来说&#xff0c;包括两个问题&#xff1a; &#xff08;1&#xff09;可变对象&#xff08;最常见的是list dict&#xff09;被意外修改的问题&#xff0c; &#xff08;2&#xff09;对参数&#xff08;parameter&#xff09;的检查问题。 这两个…

android 绘画,Android绘图基础

绘图三要素一支画笔 Paint。一张画布 Canvas。一个 Bitmap 或者一个 View 来承载这个图形。Paint常用属性setAntiAlias() 设置画笔锯齿效果。setColor() 设置画笔颜色。setTextSize() 设置字体尺寸。setStrokeWidth() 设置空心边框的宽度。setStyle() 设置画笔的风格。Canvas常…

源码0306-手势解锁

现搭建页面 // VCView.h // 06-手势解锁#import <UIKit/UIKit.h>interface VCView : UIViewend// VCView.m // 06-手势解锁#import "VCView.h"implementation VCView - (void)drawRect:(CGRect)rect {// 绘图图像UIImage *image [UIImage imageNamed:&quo…

about ajax,About 4nf.org - Arvind Gupta | Ajaxify | The Ajax Plugin

Hi Tony,That page shows various example calls and example websites, that use this plugin.Also, 4nf.org serves as an example, that is a fairly complex WordPress site.By default “previewoff” is true, so that swaps of the content div(s) are performed on cli…

numpy.random.seed()

numpy.random.seed()&#xff1a;用于指定随机数生成时使用算法的开始值&#xff0c;如果没有指定每次生成的值都不一样 如果不指定seed的值&#xff0c;那么每次随机生成的数字都不一样&#xff1a; In [17]: import numpy as npIn [18]: i 0In [19]: while i < 5:...: …

ios .framework动态库重签名

真机上运行.framework时&#xff0c;如果报 dylddyld_fatal_error:dyld: Library not loaded: rpath/XX.framework/XXReferenced from: /var/containers/Bundle/Application/DF33E1CB-0A69-4303-A22A-686E643DE922/iDoctors.app/iDoctors Reason: no suitable image found. Did…

canvars 画花

index.html<!DOCTYPE html><html><head> <title>旋转的花</title> <meta charset "utf-8"> <!--width - 可视区域的宽度&#xff0c;值可为数字或关键词device-width --> <!--height - viewport的高度--&…

android google 下拉刷新 csdn,android SwipeRefreshLayout google官方下拉刷新控件

下拉刷新功能之前一直使用的是XlistView很方便我前面的博客有介绍SwipeRefreshLayout是google官方推出的下拉刷新控件使用方法也比较简单今天就来使用下SwipeRefreshLayout 以后再需要时可以参考.首先在布局里面加入SwipeRefreshLayout 布局:Activity文件中的代码mSwipeRefresh…