2005年发布,采用Python语言编写的开源web框
早期的时候Django主做新闻和内容管理的网站
一个重量级的 Python Web框架,Django 配备了常用的大部分组件
Django的用途
Django的版本
Django的官网
django-docs-1.11-en.zip
django-docs-1.11-en/index.html
查看已安装的版本
>>> import django
>>> print(django.VERSION)
(1, 11, 8, 'final', 0)
安装
$ sudo pip3 install django
安装django的最新版本$ sudo pip3 install django[==版本]
安装django的指定版本$ sudo pip3 install django==1.11.8
$ tar -xvf Django-1.11.8.tar.gz
$ cd Django-1.11.8
$ sudo python3 setup.py install
pip3 download -d /home/tarena/django_packs django==1.11.8
Django的卸载
$ pip3 uninstall django
Django 的开发环境
$ django-admin startproject 项目名称
如:
运行
$ cd mysite1
$ python3 manage.py runserver
# 或
$ python3 manage.py runserver 5000 # 指定只能本机使用127.0.0.1的5000端口访问本机
示例:
$ django-admin startproject mysite1
$ tree mysite1/
mysite1/
├── manage.py
└── mysite1
├── __init__.py
├── settings.py
├── urls.py
└── wsgi.py
1 directory, 5 files
项目目录结构解析:
manage.py
包含项目管理的子命令, 如:
python3 manage.py runserver
启动服务python3 manage.py startapp
创建应用python3 manage.py migrate
数据库迁移...
__init__.py
wsgi.py
urls.py
settings.py
settings.py
文件介绍
BASE_DIR
DEBUG
调试模式
(用于开发中)生产环境中
(不启用调试)ALLOWED_HOSTS
127.0.0.1
, localhost
能访问本项目python3 manage.py runserver 0.0.0.0:5000
# 指定网络设备所有主机都可以通过5000端口访问(需加ALLOWED_HOSTS = ['*']
)INSTALLED_APPS
MIDDLEWARE
TEMPLATES
DATABASES
LANGUAGE_CODE
"en-us"
"zh-Hans"
TIME_ZONE
"UTC"
"Asia/Shanghai"
ROOT_URLCONF
ROOT_URLCONF = 'mysite1.urls'
注: 此模块可以通过
from django.conf import settings
导入和使用
url 即统一资源定位符 Uniform Resource Locator
作用:
说明:
URL的一般语法格式为:
protocol :// hostname[:port] / path [?query][#fragment]
如:
http://tts.tmooc.cn/video/showVideo?menuId=657421&version=AID201908#subject
注意:
“?”后是查询字符串
protocol(协议)
HTTP://
HTTPS://
file:///
hostname(主机名)
port(端口号)
path(路由地址)
query(查询) ?key1=value1&key2=value2
fragment(信息片断)
注: [] 代表其中的内容可省略
视图函数是用于接收一个浏览器请求并通过HttpResponse对象返回数据的函数。此函数可以接收浏览器请求并根据业务逻辑返回相应的内容给浏览器
视图处理的函数的语法格式:
def xxx_view(request[, 其它参数...]):
return HttpResponse对象
参数:
示例:
views.py
# file : <项目名>/views.py
from django.http import HttpResponse
def page1_view(request):
html = "这是第1个页面
"
return HttpResponse(html)
ROOT_URLCONF
指定了主路由配置列表urlpatterns的文件位置# file : <项目名>/urls.py
urlpatterns = [
url(r'^admin/', admin.site.urls),
... # 此处配置主路由
]
urlpatterns 是一个路由-视图函数映射关的列表,此列表的映射关系由url函数来确定
url() 函数
from django.conf.urls import url
每个正则表达式前面的r表示
'\'
不转义的原始字符串
建立一个小网站:
#views.py写入:
from django.http import HttpResponse
def index(request):
http='这是主页
'
return HttpResponse(http)
def page_view(request):
http="这是编号为1页面
"
return HttpResponse(http)
def page2_view(request):
http='这是编号为2页面
'
return HttpResponse(http)
#urls.py路由配置:
urlpatterns = [
url(r'^admin/', admin.site.urls),
#请求http://127.0.0.1:8000/page1 :交由views.page_view方法处理
url(r'^$',views.index),
url(r'^page1$',views.page_view),
url(r'^page2$',views.page2_view),
]
提示: 主面路由的正则是
r'^$'
思考
def pagen_view(request,n):
html = '这是编号为%s的网页
'%(n)
return HttpResponse(html)
#url.py路由配置:
urlpatterns = [
url(r'^admin/', admin.site.urls),
#请求http://127.0.0.1:8000/page1 :交由views.page_view方法处理
url(r'^page(\d+)',views.pagen_view)
]
()
提取参数后用函数位置传参传递给视图函数定义一个路由的格式为:
从路由中提取数据,做相应的操作后返回给浏览器
如:
输入: 127.0.0.1:8000/100/add/200
页面显示结果:300
输入: 127.0.0.1:8000/100/sub/200
页面显示结果:-100
输入: 127.0.0.1:8000/100/mul/200
页面显示结果:20000
def pagens_view(request,m,n,i):
if n == 'add':
s=int(m)+int(i)
html = '结果:%d
'%s
return HttpResponse(html)
if n == 'sub':
s= int(m) -int(i)
html = '结果:%d
'%s
return HttpResponse(html)
if n == 'mul':
s= int(m) * int(i)
html = '结果:%d
'%s
return HttpResponse(html)
#urls.py路由配置
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^(\d+)/(\w+)/(\d+)',views.pagens_view)
]
在url 的正则表达式中可以使用命名分组(捕获分组)
说明:
(?Ppattern)
提取参数后用函数关键字传参传递给视图函数示例:
# file : <项目名>/urls.py
# 以下示例匹配
# http://127.0.0.1:8000/person/weimingze/35
# http://127.0.0.1:8000/person/shibowen/29
# http://127.0.0.1:8000/person/xiaowei/9
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^person/(?P\w+)/(?P\d{1,2})' ,views.person_view),
]
练习:
def birth_day(request,year,month,ri):
html = year + '年' + month + '月' + ri + '日'
return HttpResponse(html)
#urls.py路由配置
urlpatterns = [
#127.0.0.1:8000/birthday/2019/9/5
url(r'^birthday/(?P\d{4})/(?P\d{1,2})/(?P\d{1,2})' ,views.birth_day),
#127.0.0.1:8000/birthday/9/5/2019
url(r'^birthday/(?P\d{1,2})/(?P\d{1,2})/(?P\d{4})' ,views.birth_day)
]
PyCharm 社区版针对Django项目调试方法
+
号添加一个自己的配置
[外链图片转存失败(img-RSTOfJS3-1567767958155)(images/request_response.png)]
根据HTTP标准,HTTP请求可以使用多种请求方法。
HTTP1.0定义了三种请求方法: GET, POST 和 HEAD方法(最常用)
HTTP1.1新增了五种请求方法:OPTIONS, PUT, DELETE, TRACE 和 CONNECT 方法。
HTTP1.1 请求详述
序号 | 方法 | 描述 |
---|---|---|
1 | GET | 请求指定的页面信息,并返回实体主体。 |
2 | HEAD | 类似于get请求,只不过返回的响应中没有具体的内容,用于获取报头 |
3 | POST | 向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中。POST请求可能会导致新的资源的建立和/或已有资源的修改。 |
4 | PUT | 从客户端向服务器传送的数据取代指定的文档的内容。 |
5 | DELETE | 请求服务器删除指定的页面。 |
6 | CONNECT | HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器。 |
7 | OPTIONS | 允许客户端查看服务器的性能。 |
8 | TRACE | 回显服务器收到的请求,主要用于测试或诊断。 |
HttpRequest对象
属性 | 描述 |
---|---|
path | 字符串,表示请求路由信息 |
path_info | URL字符串 |
method | 字符串,表示HTTP请求方法,常用值:“GET”,“POST” |
encoding | 字符串,表示提交的数据编码方式.(1,如果为None则表示使用浏览器的默认设置,一般为‘UTF-8’。2,这个属性是可写的可以通过修改它来修改访问表单数据使用的编码,接下来对属性的任何访问将使用新的enncoding值) |
GET | QueryDict查询字典对象,包含get请求方式的所有数据 |
POST | QueryDict查询字典的对象,包含post请求方式的所有数据 |
FILES | 类似于字典的对象,包含所有上传文件信息 |
COOKIES | Python字典,包含所有的cookie,键和值都为字符串 |
session | 类似于字典的对象,表示当前的回话 |
body | 字符串,请求体的内容(POST和PUT) |
environ | 字符串,客户端运行的环境变量信息 |
scheme | 请求协议(‘HTTP’/‘HTTPS’) |
request.get_full_path() | 请求的完整路径 |
request.get_host() | 请求的主机 |
request.META | 请求中的元数据(消息头) |
request.META[‘REMOTE_ADDR’] :
客户端IP地址
状态码 | 描述 |
---|---|
200 | 请求成功 |
301 | 资源(网页等)被永久转移到其他URL |
404 | 请求的资源(网页等)不存在 |
500 | 内部服务器错误 |
HTTP状态码分类
HTTP状态码由三个十进制数字组成,第一个十进制数字定义了状态码的类型,后两个数字没有分类的作用。HTTP状态码共分为5种类型:
分类 | 分类描述 |
---|---|
1** | 信息,服务器收到请求,需要请求者继续执行操作 |
2** | 成功,操作被成功接收并处理 |
3** | 重定向,需要进一步的操作以完成请求 |
4** | 客户端错误,请求包含语法错误或无法完成请求 |
5** | 服务器错误,服务器在处理请求的过程中发生了错误 |
Django中的响应对象HttpResponse:
构造函数格式:
HttpResponse(content=响应体, content_type=响应体数据类型, status=状态码)
作用:
参数 | 描述 |
---|---|
content | 表示返回的内容 |
status_code | 返回的HTTP响应状态码(默认为200) |
content_type | 指定返回数据的的MIME类型(默认为"text/html")。浏览器会根据这个属性,来显示数据。如果是text/html,那么就会解析这个字符串,如果text/plain,那么就会显示一个纯文本。 |
- 常用的Content-Type如下:
- `'text/html'`(默认的,html文件)
- `'text/plain'`(纯文本)
- `'text/css'`(css文件)
- `'text/javascript'`(js文件)
- `'multipart/form-data'`(文件提交)
- `'application/json'`(json传输)
- `'application/xml'`(xml文件)
> 注: 关键字MIME(Multipurpose Internet Mail Extensions)是指多用途互联网邮件扩展类型。
类型 | 作用 | 状态码 |
---|---|---|
HttpResponseRedirect | 重定响 | 301 |
HttpResponseNotModified | 未修改 | 304 |
HttpResponseBadRequest | 错误请求 | 400 |
HttpResponseNotFound | 没有对应的资源 | 404 |
HttpResponseForbidden | 请求被禁止 | 403 |
HttpResponseServerError | 服务器错误 | 500 |
GET请求方式中可以通过查询字符串(Query String)将数据传递给服务器
URL 格式: xxx?参数名1=值1&参数名2=值2...
http://127.0.0.1:8000/page1?a=100&b=200
服务器端接收参数
if request.method == 'GET':
处理GET请求时的业务逻辑
else:
处理其它请求的业务逻辑
request.GET['参数名'] # QueryDict
request.GET.get('参数名','默认值')
request.GET.getlist('参数名')
# mypage?a=100&b=200&c=300&b=400
# request.GET=QueryDict({'a':['100'], 'b':['200','400'], 'c':['300']})
# a = request.GET['a']
# b = request.GET['b'] # Error
<form method='get' action="/user/login">
姓名:<input type="text" name="uname">
form>
一般查询字符串的大小会受到浏览器的的限制(不建议超过2048字节)
练习:
练习:
<form method='post' action="/login">
姓名:<input type="text" name="username">
<input type='submit' value='登陆'>
form>
服务器端接收参数
if request.method == 'POST':
处理POST请求的数据并响应
else:
处理非POST 请求的响应
使用post方式接收客户端数据
request.POST['参数名'] # request.POST 绑定QueryDict
request.POST.get('参数名','')
request.POST.getlist('参数名')
取消csrf验证,否则Django将会拒绝客户端发来的POST请求
取消 csrf 验证
MIDDLEWARE = [
...
# 'django.middleware.csrf.CsrfViewMiddleware',
...
]
在form表单控件提交数据时,会自动搜索本表单控件内部的子标签的name属性及相应的值,再将这些名字和值以键-值对的形式提交给action指定的服务器相关位置
在form内能自动搜集到的name属性的标签的控件有
<input name='xxx'>
<select name='yyy'>select>
<textarea name='zzz'>textarea>
<form action="/page1" method="POST">
<input name="title" type="text" value="请输入">
<select name="gender">
<option value=1>男option>
<option value=0>女option>
select>
<textarea name="comment" rows="5" cols="10">附言...textarea>
<input type="submit" value="提交">
form>