Django学习系列之用户注册

在上篇文章的基础上,做些小小的改动.

forms.py

class RegisterForm(forms.ModelForm):
    password = forms.CharField(widget=forms.PasswordInput(attrs={‘id‘:‘pass‘}))
    sex = forms.ChoiceField(widget=forms.RadioSelect,choices=SEX_CHOICES)
    birthday = forms.DateField(required=False,widget=SelectDateWidget(years=BIRTH_YEAR_CHOICES))
    phone = forms.CharField(required=False,validators=[validate_phone])

class Meta:
        model = Register
        #fields = [‘nickname‘,‘username‘,‘password‘,‘phone‘]
        fields = ‘__all__‘

def clean(self):
        cleaned_data=super(RegisterForm,self).clean()
        nick_name=cleaned_data.get(‘nickname‘)
        username = cleaned_data.get(‘username‘)
        password = cleaned_data.get(‘password‘)
        email = cleaned_data.get(‘email‘)
        db_email = Register.objects.filter(email=email)

.....

if email in [email.email for email in db_email]:
            self._errors[‘email‘] = self.error_class([u"邮箱已经存在,请换一个!"])
        return cleaned_data

views.py

def register(request):
    sn="TC"+datetime.datetime.now().strftime("%Y%m%d%H%M%S")
    if request.method == ‘POST‘:
         regform = RegisterForm(request.POST,auto_id="%s",error_class=DivErrorList)
         if regform.is_valid():
             username = regform.cleaned_data[‘username‘]
             user=regform.save(commit=False)
             user.sn = sn
             user.save()
             return HttpResponseRedirect("/success/%s/" %username)
    else:
         regform = RegisterForm(auto_id="%s",label_suffix=":") #auto_id有3种设置:True/False/str 若是False不需要html元素中的id标识与True相反,auto_id="%s",则是field的名字
    return render(request,"register.html",{‘reg‘:regform})

def success(request,name):
    return render(request,"sucess.html",{‘username‘:name})

呵呵,成功将记录写到数据库中了。

改天,再写个用户登录(会话要考略了)。

时间: 2024-10-15 08:45:02

Django学习系列之用户注册的相关文章

Django学习系列之ModelForm

前面两篇写了有关Form与Form的验证,今天我们来写些ModelForm,因为现在的web开发都基与db驱动的,所以models.py的定义是少不掉的,但我们会发现它的定义与forms.py定义很接近,为此减少输入,我们可以使用modelForm这个模块,可减少代码输入. 先定义models.py #coding:utf-8from django.db import models SEX_CHOICES=(('male','男'),('female','女')) class Register(

Django学习系列之Form基础

Form对与一个网站来说就是一个灵魂,今天我们就来说说Django的Form概述. 本文内容来自官网,互联网及自己实验所得. 表单(forms.py)的定义: #coding:utf-8from django import formsfrom django.forms.extras.widgets import SelectDateWidget SEX_CHOICES=(('male','男'),('female','女')) BIRTH_YEAR_CHOICES = ('1980', '198

Django学习系列之django restframework

曾几何时,Ajax已经统治了Web开发中的客户端,而REST成为web世界中最流行的架构风格(architecture style).所以我们的选择变得很简单:前端ajax访问后端的RESTful API对资源进行操作Django中有一些可选的REST framework,比如django-piston,django-tasypie. 但是我和google(呵呵,不好意思)推荐这个:Django REST framework django-framework就是定义一个url,可以利用这个url

Django学习系列之中间件

中间件的定义 中间件是一个.一个的管道,如果相对任何所有的通过Django的请求进行管理都需要自定义中间件 中间件可以对进来的请求和出去的请求进行控制 中间件是一类 django请求生命周期 自定义中间件 process_request(self,request): 请求到达之后之后先执行这个中间件 process_view(self, request, callback, callback_args, callback_kwargs): process_exception(self, requ

Django学习系列之ORM-QuerySetAPI

基本操作 # 增 models.Tb1.objects.create(c1='xx', c2='oo') #增加一条数据,可以接受字典类型数据 **kwargs obj = models.Tb1(c1='xx', c2='oo') obj.save() dic = {'c1':'xx','c2':'oo'} models.Tb1.objects.create(**dic) #Form的产出结果是一个字典,可以根据这个Form的字典和**直接在数据库创建数据 # 查 models.Tb1.obje

Django学习系列之Form表单和ajax

ajax 通过ajax发送一条数据 定义urls.py from django.conf.urls import url from django.contrib import admin from cmdb import views urlpatterns = [ url(r'^ajax_demo/', views.ajax_demo), ] 定义views.py from django.shortcuts import render from django.shortcuts import H

Django学习系列之路由系统

一.基于App的路由 作用: 根据App对路由规则进行分类,在全局urls.py包含某个项目的urls.py 示例 定义全局urls.py(全局路由系统) #导入include from django.conf.urls import url,include from django.contrib import admin #导入app下的view函数 from learn import views urlpatterns = [ url(r'^admin/', admin.site.urls)

Django学习系列之模型

Django ORM简介 介绍 关系对象映射(Object Relational Mapping) Django中遵循Code first的原则,即根据代码中定义的类生成数据库 ORM中: 我们写的类表示数据库的表名 根据这个类创建的对象是表结构 Django ORM 一对多关系例子 定义urls.py from django.conf.urls import url from django.contrib import admin #导入django admin admin.autodisco

Django学习系列之CSRF

Django CSRF 什么是CSRF CSRF, Cross Site Request Forgery, 跨站点伪造请求.举例来讲,某个恶意的网站上有一个指向你的网站的链接,如果 某个用户已经登录到你的网站上了,那么当这个用户点击这个恶意网站上的那个链接时,就会向你的网站发来一个请求, 你的网站会以为这个请求是用户自己发来的,其实呢,这个请求是那个恶意网站伪造的 Django提供的CSRF防护机制 django 第一次响应来自某个客户端的请求时,会在服务器端随机生成一个 token,把这个 t