django 快速实现注册

 

前言css

  对于web开来讲,用户登录、注册、文件上传等是最基础的功能,针对不一样的web框架,相关的文章很是多,但搜索以后发现大多都不具备完整性,对于想学习web开发的新手来讲不具备很强的操做性;对于web应用来讲,包括数据库的建立,前端页面的开发,以及中间逻辑层的处理三部分。html

  本系列以可操做性为主,介绍如何经过django web框架来实现一些简单的功能。每一章都具备完整性和独立性。使用新手在动手作的过程当中体会web开发的过程,过程当中细节请参考相关文档。前端

本操做的环境:python

===================linux

deepin linux 2013(基于ubuntu)web

python 2.7数据库

Django 1.6.2django

===================ubuntu

 

建立项目与应用                                                                                          session

 

#建立项目
fnngj@fnngj-H24X:~/djpy$ django-admin.py startproject mysite3
fnngj@fnngj-H24X:~/djpy$ cd mysite3
#在项目下建立一个account应用
fnngj@fnngj-H24X:~/djpy/mysite3$ python manage.py startapp account

目录结构以下:

打开mysite3/mysite3/settings.py文件,将应用添加进去:

# Application definition

INSTALLED_APPS = (
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'account',
)

 

 

设计Model(数据库)                                                                          

 

打开mysite3/account/models.py文件,添加以下内容

from django.db import models # Create your models here.
class User(models.Model): username = models.CharField(max_length=50) password = models.CharField(max_length=50) email = models.EmailField()

按照惯例先建立数据库,建立三个字段,用户存放用户名、密码、email 地址等。

下面进行数据库的同步

fnngj@fnngj-H24X:~/djpy/mysite3$ python manage.py syncdb
Creating tables ...
Creating table django_admin_log
Creating table auth_permission
Creating table auth_group_permissions
Creating table auth_group
Creating table auth_user_groups
Creating table auth_user_user_permissions
Creating table auth_user
Creating table django_content_type
Creating table django_session
Creating table account_user
You just installed Django's auth system, which means you don't have any superusers defined.
Would you like to create one now? (yes/no): yes 输入yes/no

Username (leave blank to use 'fnngj'):     用户名(默认当前系统用户名)
Email address: fnngj@126.com     邮箱地址
Password:    密码
Password (again):    确认密码
Superuser created successfully.
Installing custom SQL ...
Installing indexes ...
Installed 0 object(s) from 0 fixture(s)

最后生成的 account_user 表就是咱们models.py 中所建立的User类。Django 提供了他们之间的对应关系。

 

 

建立视图(逻辑层)                                                                             

 

打开mysite3/account/views.py 文件:

#coding=utf-8
from django.shortcuts import render from django import forms from django.shortcuts import render_to_response from django.http import HttpResponse,HttpResponseRedirect from django.template import RequestContext from account.models import User #定义表单模型
class UserForm(forms.Form): username = forms.CharField(label='用户名:',max_length=100) passworld = forms.CharField(label='密码:',widget=forms.PasswordInput()) email = forms.EmailField(label='电子邮件:') # Create your views here.
def register(request): if request.method == "POST": uf = UserForm(request.POST) if uf.is_valid(): #获取表单信息
            username = uf.cleaned_data['username'] passworld = uf.cleaned_data['passworld'] email = uf.cleaned_data['email'] #将表单写入数据库
            user = User() user.username = username user.passworld = passworld user.email = email user.save() #返回注册成功页面
            return render_to_response('success.html',{'username':username}) else: uf = UserForm() return render_to_response('register.html',{'uf':uf})

的这个逻辑中主要作了几件事,首先提供给用户一个注册页面(register.html),UserForm类定义了表单在注册页面上的显示。接受用户填写的表单信息,而后将表单信息写入到数据库,最后返回给用户一个注册成功的页面(success.html)

 

 

建立模板文件(前端页面)                                                                   

 

在逻辑层提到了两个页面,一个注册页,一个注册成功页面。因此咱们要把这两个页面建立出来。

先在mysite3/account/目录下建立templates目录,接着在mysite3/account/templates/目录下建立register.html 文件:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <title>用户注册</title>
</head>
  <style type="text/css"> body{color:#efd;background:#453;padding:0 5em;margin:0} h1{padding:2em 1em;background:#675} h2{color:#bf8;border-top:1px dotted #fff;margin-top:2em} p{margin:1em 0}
  </style>
<body>
<h1>注册页面:</h1>
<form method = 'post' enctype="multipart/form-data"> {{uf.as_p}} <input type="submit" value = "ok" />
</form>
</body>
</html>

mysite3/account/templates/目录下建立success.html 文件:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <title></title>
</head>
<body>
    <h1>恭喜{{username}},注册成功!</h1>
</form>
</body>
</html>

 

设置模板路径

打开mysite3/mysite3/settings.py文件,在底部添加:

#template
TEMPLATE_DIRS=( '/home/fnngj/djpy/mysite3/account/templates' )

 

 

设置URL                                                                                                  

 

设置URL的配置也是django web框架的一大特点。打开mysite3/mysite3/urls.py:

from django.conf.urls import patterns, include, url from django.contrib import admin admin.autodiscover() urlpatterns = patterns('', # Examples:
    # url(r'^$', 'mysite3.views.home', name='home'),
    # url(r'^blog/', include('blog.urls')),
 url(r'^admin/', include(admin.site.urls)), url(r'^account/', include('account.urls')), )

 

在mysite3/account/目录下建立urls.py文件:

from django.conf.urls import patterns, url
from account import views

 
urlpatterns = patterns('',
    url(r'^$', views.register, name='register'),
    url(r'^register/$',views.register,name = 'register'),
)

这里人配置表示:访问

http://127.0.0.1:8000/account/

http://127.0.0.1:8000/account/register/

都会指向一个注册页面。

 

 

体验注册                                                                                                   

 

当全部工做都完成以后,下面体验一下咱们的注册功能吧。

启动服务:

fnngj@fnngj-H24X:~/djpy/mysite3$ python manage.py runserver
Validating models...

0 errors found
May 21, 2014 - 14:31:32
Django version 1.6.2, using settings 'mysite3.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CONTROL-C.

访问注册页面:

由于在register.html 文件中加了一点样式,因此看上去好看了一点,但做为一个审美的人观念的人没法容忍这样丑陋的页面存在。

以避免错误的再次出现,

打开mysite3/mysite3/settings.py文件,将下面一行代码注释:

MIDDLEWARE_CLASSES = ( 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', #'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', )

 

如今能够做为一个用户去填写表单了。

 

 

 

注册的用户哪儿去了? 

 

你依然能够像昨天同样去查询数据库,但为何不利用admin呢?

打开mysite3/account/models.py文件:

from django.db import models from django.contrib import admin # Create your models here.
class User(models.Model): username = models.CharField(max_length=50) password = models.CharField(max_length=50) email = models.EmailField() class UserAdmin(admin.ModelAdmin): list_display = ('username','email') admin.site.register(User,UserAdmin)

从新初始化数据库:

fnngj@fnngj-H24X:~/djpy/mysite3$ python manage.py syncdb
Creating tables ...
Installing custom SQL ...
Installing indexes ...
Installed 0 object(s) from 0 fixture(s)

登录admin 后台

http://127.0.0.1:8000/admin/

登录所须要的用户名和密码就是咱们第一次同步数据库时所设置

而后咱们就看到刚刚注册的那个用户信息。

 

本文以实现基本功能为主,固然你能够在此基础上作更多的事。对用户注册信息的验证,须要再次确认密码,修改一个漂亮的样式等。若是有用点个赞吧。

相关文章
相关标签/搜索