Django 创建第一个项目
使用 django-admin.py
来创建 HelloWorld 项目:
django-admin.py startproject HelloWorld
创建完成后我们可以查看下项目的目录结构:
[root@solar HelloWorld]# tree
.
|-- HelloWorld
| |-- __init__.py
| |-- settings.py
| |-- urls.py
| `-- wsgi.py
`-- manage.py
目录说明:
- HelloWorld: 项目的容器。
- manage.py: 一个实用的命令行工具,可让你以各种方式与该 Django 项目进行交互
- HelloWorld/init.py:一个空文件,告诉 Python 该目录是一个 Python 包。
- HelloWorld/settings.py:该 Django 项目的设置/配置.
- HelloWorld/urls.py:该 Django 项目的 URL 声明; 一份由 Django 驱动的网站"目录"。
- HelloWorld/wsgi.py: 一个 WSGI 兼容的 Web 服务器的入口,以便运行你的项目。
接下来我们进入 HelloWorld 目录输入以下命令,启动服务器:
python manage.py runserver 0.0.0.0:8000
视图和 URL 配置
在先前创建的 HelloWorld 目录下的 HelloWorld 目录新建一个 view.py 文件,并输入代码:
from django.http import HttpResponse
def hello(request):
return HttpResponse("Hello world ! ")
接着,绑定 URL 与视图函数。打开 urls.py 文件,删除原来代码,将以下代码复制粘贴到 urls.py 文件中:
from django.conf.urls import *
from HelloWorld.view import hello
urlpatterns = [url(r'^hello/$', hello),]
Django 模板
上面我们使用 django.http.HttpResponse() 来输出"Hello World!"。该方式将数据与视图混合在一起,不符合Django的MVC思想。
在 HelloWorld 目录底下创建 templates 目录(与manage.py同级)并建立 hello.html文件:
<h1>{{ hello }}</h1>
接下来我们需要向Django说明模板文件的路径,修改HelloWorld/settings.py,修改 TEMPLATES 中的 DIRS 为 [BASE_DIR+"/templates",]
修改 view.py,增加一个新的对象,用于向模板提交数据:
from django.shortcuts import render
def hello(request):
context = {}
context['hello'] = 'Hello World!'
return render(request, 'hello.html', context)
这里使用render来替代之前使用的HttpResponse。render还使用了一个字典context作为参数。
context 字典中元素的键值 "hello" 对应了模板中的变量 "{{ hello }}"。
数据库配置
在项目的 settings.py 文件中找到 DATABASES 配置项
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 或者使用 mysql.connector.django
'NAME': 'test',
'USER': 'test',
'PASSWORD': 'test123',
'HOST':'localhost',
'PORT':'3306',
}
}
定义模型
创建 APP
Django规定,如果要使用模型,必须要创建一个app。我们使用以下命令创建一个 TestModel 的 app:
python manage.py startapp TestModel
修改 TestModel/models.py:
# models.py
from django.db import models
class Test(models.Model):
name = models.CharField(max_length=20)
以上的类名代表了数据库表名,且继承了models.Model,类里面的字段代表数据表中的字段(name),数据类型则由CharField(相当于varchar)、DateField(相当于datetime), max_length 参数限定长度。
接下来在settings.py中找到INSTALLED_APPS这一项,如下:
'TestModel', # 添加此项
在命令行中运行python manage.py syncdb,看到几行"Creating table…"的字样,你的数据表就创建好了。表名组成结构为:app名_类名(如:TestModel_test)。
数据库操作
接下来我们在 HelloWorld 目录中添加 testdb.py 文件,并修改urls.py:
from django.conf.urls import *
from HelloWorld.view import hello
from HelloWorld.testdb import testdb
urlpatterns = patterns("", ('^hello/$', hello), ('^testdb/$', testdb),)
添加数据
添加数据需要先创建对象,然后再执行 save 函数,相当于SQL中的INSERT:
from django.http import HttpResponse
from TestModel.models import Test
数据库操作
def testdb(request):
test1 = Test(name='aaa')
test1.save()
return HttpResponse("<p>数据添加成功!</p>")
访问http://xxxx:8000/testdb/ 就可以看到数据添加成功的提示。
获取数据
#通过objects模型管理器的all()获得所有数据行,相当于sql中的select * from
list = Test.objects.all()
testx1 = Test.objects.get(id=1)
#限制返回的数据 相当于SQL中的OFFSET 0 LIMIT 2;
Test.obiects.order_by('name')[0:2]
#排序
Test.objects.order_by("id")
#上面的方法可以连锁使用
Test.obiects.filter(name=' ').order_by(id)
更新数据
save() 或 update():
test1 = Test.objects.get(id=1)
test1.name = 'xxx'
test1.save()
#另一种方式
Test.objects.filter(id=1).update(name='new name')
删除数据
Test.objects.filter(id=1).delete()
HTTP请求
Post
在tmplate 创建 post.html:
<form action="/search-post/" method="post">
{% csrf_token %}
<input type="text" name="q">
<input type="submit" value="Submit">
</form>
<p>{{ rlt }}</p>
在模板的末尾,我们增加一个rlt记号,为表格处理结果预留位置。
表格后面还有一个{% csrf_token %}的标签。csrf全称是Cross Site Request Forgery。这是Django提供的防止伪装提交请求的功能。POST方法提交的表格,必须有此标签。
在HelloWorld目录下新建 search2.py 文件并使用 search_post 函数来处理 POST 请求:
# -*- coding: utf-8 -*-
from django.shortcuts import render
from django.core.context_processors import csrf
# 接收POST请求数据
def search_post(request):
ctx ={}
ctx.update(csrf(request))
if request.POST:
ctx['rlt'] = request.POST['q']
return render(request, "post.html", ctx)
urls.py 规则修改为如下形式:
from django.conf.urls import *
from HelloWorld.view import hello
from HelloWorld.testdb import testdb
from HelloWorld import search
from HelloWorld import search2
urlpatterns = patterns("",
('^hello/$', hello),
('^testdb/$', testdb),
(r'^search-form/$', search.search_form),
(r'^search/$', search.search),
(r'^search-post/$', search2.search_post),
)
Request 对象
每个view函数的第一个参数是一个HttpRequest对象
Django Admin 管理工具
创建超级用户
python manage.py createsuperuser
为了让admin界面管理某个数据模型,我们需要先注册该数据模型到admin。比如,我们之前在 TestModel 中已经创建了模型 Test 。修改 TestModel/admin.py:
from django.contrib import admin
from TestModel.models import Test
# Register your models here.
admin.site.register(Test)