[Python] 使用Django开发Web框架

长平狐 发布于 2013/06/03 15:03
阅读 1K+
收藏 0

Django Web框架简介

Django 项目是一个 python[1]定制框架,它源自一个在线新闻 Web 站点,于 2005 年以开源的形式被释放出来。Django 框架的核心组件有:
  • 用于创建模型的对象关系映射
  • 为最终用户设计的完美管理界面
  • 一流的 URL 设计
  • 设计者友好的模板语言
  • 缓存系统。
Django符合MTV架构

Django的安装

Django的安装有两种方法,具体可参考官网( https://www.djangoproject.com/download/),这里采用第二种方法,即Option 2. Get the latest development version,具体如下:
[dw_mon@TDDBA ~]$ git clone https://github.com/django/django.git
[dw_mon@TDDBA install]$ cd django
[dw_mon@TDDBA django]$ python setup.py install
安装成功后,就可以使用Django的管理工具了django-admin.py

Django项目和应用程序

通过以下命令创建一个Django项目:
[dw_mon@TDDBA project]$ django-admin.py startproject eshop
以上命令会在当前目录下创建eshop的文件夹(即项目), 其中包含了运行 Django 项目所需要的基本配置文件:
[dw_mon@TDDBA eshop]$ ls
__init__.py  settings.py  urls.py  wsgi.py

接着,我们要在该项目下创建一个应用程序order:
[dw_mon@TDDBA eshop]$ python manage.py startapp order
以上命令会在当前目录下创建一个order目录,该目录有如下文件:
[dw_mon@TDDBA eshop]$ cd order
[dw_mon@TDDBA products]$ ls
admin.py  __init__.py  models.py  tests.py  views.py

提供应用程序在项目中的位置纯粹是为新 Django 开发人员建立的一种惯例,并不是必需的。
为了使 Django 认识到新应用程序的存在,还需要向 settings.py 文件中的 INSTALLED_APPS 添加一个条目:
INSTALLED_APPS = (
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'order',
)


Django数据模型

Django 提供了自己的对象关系型数据映射组件(object-relational mapper,ORM)库,它可以通过 Python 对象接口支持动态数据库访问。

ORM 目前提供了对 PostgreSQL、MySQL、SQLite 和 Microsoft® SQL 数据库的支持。
这里采用默认的SQLite, SQLite 只需要指定数据库引擎和数据库名即可,而其它数据库还需要制定用户名、密码等。
settings.py 文件中的 DATABASES)
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

下面编辑order/models.py模块,定义Python对象与数据库表中的映射关系。
from django.db import models

class Product(models.Model):
    name = models.CharField('product name', max_length=30)
    price = models.FloatField('price', default=10)

    def __unicode__(self):
        return "%s --> %f" %(self.name,self.price)


然后,运行以下命令就可以在数据库中创建表:

[dw_mon@TDDBA eshop]$ python manage.py syncdb

注意, syncdb  命令要求我们创建一个超级用户帐号。这是因为 django.contrib.auth 应用程序(提供基本的用户身份验证功能)默认情况下是在 INSTALLED_APPS 设置中提供的。超级用户名和密码用来登录将在下一节介绍的管理工具。记住,这是 Django 的超级用户,而不是系统的超级用户。

上面的命令执行完之后,会产生一个db.sqlite3文件用于存储数据文件:
[dw_mon@TDDBA eshop]$ ls
db.sqlite3  eshop  manage.py  order


Django的管理工具

管理工具是 Django 提供的一个应用程序。与 order  应用程序一样,在使用之前也必须进行安装。第一个步骤是将应用程序的模块( django.contrib.admin )添加到 INSTALLED_APPS 设置中:
INSTALLED_APPS = (
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'order',
    'django.contrib.admin',
)

使管理工具可以通过 urls.py 使用(编辑urls.py文件):
from django.conf.urls import patterns, include, url

from django.contrib import admin
admin.autodiscover()

urlpatterns = patterns('',
    # Examples:
    # url(r'^$', 'eshop.views.home', name='home'),
    # url(r'^blog/', include('blog.urls')),

    url(r'^admin/', include(admin.site.urls)),
)

这个管理应用程序有自己的数据库模型,但也需要进行安装。我们可以再次使用  syncdb  命令来完成这个过程:
[dw_mon@TDDBA eshop]$ python manage.py syncdb

要查看这个管理工具,可以使用 Django 提供的测试服务器。

[dw_mon@TDDBA eshop]$ python manage.py runserver 10.249.76.133:8004
Validating models...

0 errors found
May 12, 2013 - 15:10:59
Django version 1.6, using settings 'eshop.settings'
Starting development server at http://10.249.76.133:8004/
Quit the server with CONTROL-C.
现在可以使用http://10.249.76.133:8004/admin 启动管理工具,并使用前面创建的超级用户帐号进行登录。

把自己定义的模块注入到管理工具

为了让管理工具可以管理我们之前定义的product对象,我们需要在order目录下编辑admin.py文件,注册自己的模块。
from django.contrib import admin
from models import Product
# Register your models here.
admin.site.register(Product)

刷新一下网页,就可以发现Product出现在管理页面。


原文链接:http://blog.csdn.net/u010415792/article/details/8918023
加载中
返回顶部
顶部