1.环境安装
django支持python3+,且只支持python2.7
1)安装python
https://www.python.org/downloads/release/python-2715/

2)安装django

django 对python的支持情况
安装1.10.2版本django
pip install Django==1.10.2

判断django是否安装成功:
python -m django --version
2.创建django
安装完django后命令行中就多了行django命令,选择好安装目录
django-amdin startproject myblog (项目名称:myblog 定义好名称后运用时不建议修改,配置文件中也是以myblog命名配置)
image.png
项目结构:

1.manage.py
与项目进行交互的命令行工具集的入口(项目管理器)
启动命令:
python manage.py runserver
python manage.py runserver + 端口号
默认端口 8000
image.png
2.wsgi.py(基本不用修改)
WSGI(Python Web Server Gateway Interface)
python服务器网关接口
python应用与web服务器之间的接口
3.urls.py
配置url
4.settings.py
项目的总配置文件
里面包含数据库、web应用、时间等各种配置
1.BASE_DIR :项目根目录
2.SECRET_KEY:项目安全码
3.DEBUG:不要在实际生产中打开
4.ALLOWED_HOSTS:只允许外部访问地址
5.INSTALLED_APPS:django应用
6.MIDDLEWARE:中间件
7.ROOT_URLCONF:url根路径
8.TEMPLATES:模板文件
9.DATABASES:数据库配置,默认是sqlite,如要自定义数据库到 https://docs.djangoproject.com/en/1.10/ref/settings/#databases 中寻找配置方式
10.AUTH_PASSWORD_VALIDATORS:密码认证
11.STATIC_URL:静态文件
5.init.py
声明模块文件,一般为空
3.创建应用
1.打开命令行,进入项目中manage.py同级目录
2. 输入命令:python manage.py startapp blog

3. 添加应用名到settings.py 中的INSTALLED_APPS中

4.应用目录介绍
1.migrations
数据移植(迁移) 模块
2.admin.py
该应用的后台管理系统配置
3.apps.py
该应用 的配置
1.8+后自动生成
4.models.py
数据模块,使用ORM框架,类似MVC的模型
5.test.py
自动化测试模块
6.views.py
执行响应代码所在模块
代码逻辑处理的主要地点
项目大部分代码在这编写
5.创建第一个响应
代码:
from django.shortcuts import render
from django.http import HttpResponse
# Create your views here.
def index(request):
return HttpResponse("Hello,world!")
配置url:myblog>urls.py

查看结果:

6.配置url
1)在blog目录下创建urls.py

from django.conf.urls import url
from . import views
urlpatterns = [
url(r'^index/', views.index),
]
2)在urls.py中引用blog.urls

7.Template
1.
Django使用了一种特殊的模板语言(Django Template Language,DTL)
可以使用第三方模板Jinja2


1)在APP的根目录下创建Templates的目录
2)在该目录下创建HTML文件
3)在views.py中返回render
from django.shortcuts import render
from django.http import HttpResponse
#render包含三个参数,第一个是request请求,第二个是返回页面地址(即html),第三个为返回数据
def index(request):
return render(request, 'index.html')
2.DTL初步使用
render()函数中支持一个dict类型参数(键值对)
该字典是后台参数传递到模板的参数,键为参数名
在模板中使用{{参数名}}来直接使用
views.py:
from django.shortcuts import render
from django.http import HttpResponse
def index(request):
return render(request, 'index.html', {'hello': 'Hello,Blog!'})
index.html:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>{{hello}}</h1>
</body>
</html>

***Django第一个坑
Django查找Template
Django按照INSTALLED_APP中的添加顺序查找Templates
不同APP下Templates目录中的同名.html文件会造成冲突
解决方案
在APP的Templates目录下创建以APP名为名称的目录
将html文件放入新创建的目录下
image.png
8.Models
ORM(对象关系映射)
实现了对象与数据之间的映射
隐藏了数据访问的细节,不需要编写sql语句
通常,一个Model对应数据库的一张数据表
Django中Models以类的形式表现
它包含了一些基本字段以及数据的一些行为
1)在应用根目录下创建models.py,并引入models模块(Django已完成)
2)创建类,继承models.Model,该类即是一张数据表
3)在类中创建字段
字段即类里面的属性(变量)
attr=models.CharField(max_length=64)
models.py:
from __future__ import unicode_literals
from django.db import models
class Article(models.Model):
title = models.CharField(max_length=32, default='Title')
content = models.TextField(nul=True)
4)生成数据表
1.命令行中进入manage.py同级目录
2.执行python manage.py makemigrations app名(可选)
3.再执行python manage.py migrate
4.Django在app/migrations/目录下生成移植文件
5.执行python manage.py sqlmigrate 应用名 文件id 查看SQL语句
6.默认sqlite3的数据库在项目根目录下db.sqlite3
5)页面数据呈现
1.views.py中import models
2.article = models.Article.objects.get(pk=1)
3. render(request,page,{'article' : article})
views.py:
from django.shortcuts import render
from django.http import HttpResponse
from . import models
def index(request):
article = models.Article.objects.get(pk=1)
return render(request, 'blog/index.html', {'article': article})
index.html:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>{{article.id}}</h1>
<h1>{{article.title}}</h1>
<h1>{{article.content}}</h1>
</body>
</html>
image.png
9.Admin
Admin是Django自带的一个功能强大的自动化数据管理页面
被授权的用户可直接在Admin中管理数据库
Django提供了许多针对Admin的定制功能
1)配置Admin
1.创建用户
python manage.py createsuperuser 创建超级用户
2.localhost:8000/admin/ Admin 入口
3.修改settings.py 中 LANGUAGE_CODE='zh_Hans' 英文变中文操作界面
2)配置应用
1.在应用下admin.py中引入自身的models模块(或里面的模型类)
2.编辑admin.py: admin.site.register(models.Article)
admin.py:
from django.contrib import admin
from models import Article
admin.site.register(Article)
3.当前显示很不方便,需要修改数据默认显示名称

在Article类下添加一个方法
根据Python版本选择_str_(self) 【3.0+】 或 _unicode_(self) 【2.7+】
return self.title
models.py:
from __future__ import unicode_literals
from django.db import models
class Article(models.Model):
title = models.CharField(max_length=32, default='Title')
content = models.TextField(null=True)
def __unicode__(self):
return self.title

网友评论