前言

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

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

本操作的环境:

===================

deepin linux 2013(基于ubuntu)

python 2.7

Django 1.6.2

===================

创建项目与应用                                                                                          

#创建项目 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 后台这里要创建superuser

http://127.0.0.1:8000/admin/

登陆所需要的用户名和密码就是我们第一次同步数据库时所设置。

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

错误:CSRF token missing

把setting里面的csrf注册掉就可以但是可能不是很好,先这样用着吧

Django实现注册的更多相关文章

  1. Django admin注册model究竟要怎么写才优雅 批量注册model

    比如在Django admin 注册models时,会用到. 对于APP里自带的models,可以使用这种方式注册. from django.contrib import admin # Regist ...

  2. Django admin注册model究竟要怎么写才优雅

    比如在Django admin 注册models时,会用到. 对于APP里自带的models,可以使用这种方式注册. from django.contrib import admin # Regist ...

  3. Django实现注册页面_头像上传

    Django实现注册页面_头像上传 Django实现注册页面_头像上传 1.urls.py 配置路由 from django.conf.urls import url from django.cont ...

  4. [py][mx]django邮箱注册的验证码部分-django-simple-captcha库使用

    邮箱注册-验证码 验证码使用第三方库django-simple-captcha 这个安装图形插件步骤官网有哦 - 1.Install django-simple-captcha via pip: pi ...

  5. Django 登陆注册实现

    路由层 from django.conf.urls import url from django.contrib import admin from app01 import views urlpat ...

  6. django 登录注册注销

    一.设计数据模型 1.数据库模型设计 作为一个用户登录和注册项目,需要保存的都是各种用户的相关信息.很显然,我们至少需要一张用户表User,在用户表里需要保存下面的信息: 用户名 密码 邮箱地址 性别 ...

  7. django url注册器组件, 响应器组件, 分页器组件

    一.url注册器的使用 1.1导入模块 from django.urls import re_path, include from .serializer import views from rest ...

  8. Django+bootstrap+注册登录系统

    转自:https://www.cnblogs.com/robindong/p/9610057.html Robin_D 博客园 首页 新随笔 联系 订阅 管理 随笔 - 10  文章 - 0  评论 ...

  9. 关于Django auth注册登录模块的具体使用

    from django.urls import path from . import views urlpatterns = [ #主页,用来显示类别等其他数据 path('',views.index ...

随机推荐

  1. 【http】四种常见的 POST 提交数据方式

    来源:http://www.cnblogs.com/aaronjs/p/4165049.html HTTP/1.1 协议规定的 HTTP 请求方法有 OPTIONS.GET.HEAD.POST.PUT ...

  2. Python 小爬虫流程总结

    接触Python3一个月了,在此分享一下知识点,也算是温故而知新了. 接触python之前是做前端的.一直希望接触面能深一点.因工作需求开始学python,几乎做的都是爬虫..第一个demo就是爬取X ...

  3. Linux学习记录

    ---恢复内容开始--- linux与unix的关系 linux是借鉴了unix设计思想,也称linux位类unix系统. Linux常用命令 1.命令基本格式 命令[选项][参数] 注意:个别命令不 ...

  4. VC 鼠标滚轮事件控制绘图的问题

    问题描述: 在MFC中绘制数据曲线,通过鼠标滚轮来进行放大缩小操作.在使用滚轮事件时,发现如果数据量较大,会出现卡顿. 解决方案: 鼠标滚轮事件会进行重复绘图,考虑在鼠标滚轮结束之后再重绘: 在鼠标滚 ...

  5. 配置Samba共享服务器

    安装samba: sudo apt-get install samba samba-common 由于是挂载另一个磁盘,并作为共享文件存放地: 列出磁盘名和ID air@air-device:~$ s ...

  6. Swift - UIBezierPath

    使用UIBezierPath可以创建基于矢量的路径.使用此类可以定义简单的形状,如椭圆.矩形或者有多个直线和曲线段组成的形状等.主要用到的该类的属性包括 moveToPoint: //设置起始点 ad ...

  7. 解决select2在bootstrap的modal中默认不显示的问题

    在Bootstrap中的Modal,select2插件会有不显示,因为其z-index小于modal,还有另外一个问题是,修正z-index之后,select2不会自动失去焦点的问题.代码解决如下: ...

  8. phpcms 整合 discuz!

    第一步,进入discuz后台,点击UCenter菜单,然后点击应用管理,接着点击右侧的添加新应用按钮 然后填写应用相关信息: 1.应用类型选择“其他” 2.应该名称填写“phpcms” //此处可以自 ...

  9. 《UML大战需求分析》阅读随笔(四)

    状态机图(State Machine Diagram),状态机图是通过描述某事物状态的改变来展现流程的.一般适用于流程围绕某个事物展开,例如请假的流程就围绕请假条的展开.语法,开始于结束符号,实心圆表 ...

  10. 在HyperlinkButton的URL地址里附加多个参数(以http get的方式)

    1.使用 Uri(string uriString,UriType type)创建Uri对象:new Uri("/navigatingPage?key1=value1&key2=va ...