前言

  对于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/noUsername (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 = usernameuser.passworld = passworlduser.email = emailuser.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, urlfrom 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 viewsurlpatterns = 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/

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

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

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

django 快速实现注册相关推荐

  1. django 快速实现注册(四)

    一.创建项目与应用  #创建项目 fnngj@fnngj-H24X:~/djpy$ django-admin.py startproject mysite3 fnngj@fnngj-H24X:~/dj ...

  2. python django 快速实现注册,登录,注销

    临近年底,各种忙,好久没更新博客了,2017春节假期在即,距下班还有2小时,难得闲下来,来撸一手django简单的web注册,登录,注销. 环   境:centos 6.4 64bit python ...

  3. django2.0 快速实现注册

    django 快速实现注册 本操作环境: 虚拟环境:django2.0 python3.5(应该python3.6都可以使用) window10 1.创建项目与应用(项目和应用都是自己制定的) 创建项 ...

  4. pythondjango搭建数据管理平台,使用Django快速搭建简单的数据管理后台

    使用Django快速搭建简单的数据管理后台 概述 需求描述: 数据表已建好,能可视化操作增删改查,避免直接操作数据库 简版的管理系统 环境 Windows 10 x64 Python 3.6.3 (A ...

  5. django快速集成富文本编辑器wangeditor

    django快速集成富文本编辑器wangeditor django是python栈一款优秀的web开发框架,也是python栈web开发框架中使用占比最高的开发框架,至于其是否足够优秀不言自明,自带的 ...

  6. 【Python全栈100天学习笔记】Day41 Django快速上手

    快速上手 Web开发的早期阶段,开发者需要手动编写每个页面,例如一个新闻门户网站,每天都要修改它的HTML页面,随着网站规模和体量的增大,这种方式就变得极度糟糕.为了解决这个问题,开发人员想到了用外部 ...

  7. 41.Django快速上手

    Django快速上手 Web开发的早期阶段,开发者需要手动编写每个页面,例如一个新闻门户网站,每天都要修改它的HTML页面,随着网站规模和体量的增大,这种做法一定是非常糟糕的.为了解决这个问题,开发人 ...

  8. django 快速实现文件上传(django2.0)

    django2.0 快速实现文件上传 本操作环境: 虚拟环境:django2.0 python3.5(应该python3.6都可以使用) window10 1.创建项目与应用(项目和应用都是自己制定的 ...

  9. Python学习笔记:7.2.3 Django快速建站 - 表单

    前言:本文是学习网易微专业的<python全栈工程师 - Django快速建站>课程的笔记,欢迎学习交流.同时感谢老师们的精彩传授! 一.课程目标 创建用户管理应用 开发用户登录功能 理解 ...

最新文章

  1. 面向初学者的10个热门计算机视觉项目
  2. 上海市金山区财政局容灾项目竞争性谈判600万元
  3. 网易数帆Curve加入PolarDB开源数据库社区
  4. php无嵌套遍历多维数组,不递归怎么遍历多维数组(维数不定)
  5. 功能强大的JavaScript 拖拽库 SortableJS
  6. RHEL6网络无人值守安装
  7. 别乱提交代码了,你必须知道的 Git 分支开发规范!
  8. 基于Python和MySQL的学生信息管理系统
  9. 必看 | 机器视觉基础入门
  10. python for ArcGIS 绘制广州市板块地图
  11. java中json获取key值_如何获取JsonObject中key的值
  12. kali-Linux局域网渗透之Win2008
  13. Python中过滤列表中全部奇数
  14. 三维地图3DGIS平台技术指标要求规划
  15. IC基础知识(六)SV中default input #1 output #1的解释
  16. Keras区分狗和猫
  17. 如何改掉自己的坏习惯
  18. 学习管理!!中国历史上最经典的7个智慧案例
  19. 制造业车间生产管理系统(精诚MES)
  20. win7 64位下如何安装配置mysql-5.7.17-winx64

热门文章

  1. 【OkHttp】OkHttp 源码分析 ( OkHttpClient.Builder 构造器源码分析 )
  2. Linux Shell的输入彩色字体
  3. 数据库各个派系的起源和应用场景
  4. 判断两个数组内容是否相同
  5. 操作笔记:tomcat在正式环境的常见问题和idea的远程调试
  6. (转)fastcgi简介
  7. Winrar目录穿越漏洞复现
  8. 通过NVIDIA PilotNet,人人都能变成人工智能的老师
  9. 支付宝变身新宠,钱包族再也“不差钱”
  10. Matplotlib 中文用户指南 7.2 Python shell 中使用 Matplotlib