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
文件介绍
https://docs.djangoproject.com/en/1.11/ref/settings/
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(查询)
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表示
'\'
不转义的原始字符串
提示: 主页路由的正则是
r'^$'
()
提取参数后用函数位置传参传递给视图函数定义一个路由的格式为:
从路由中提取数据,做相应的操作后返回给浏览器
如:
输入: 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
在url 的正则表达式中可以使用命名分组(捕获分组)
说明:
(?Ppattern)
提取参数后用函数关键字传参传递给视图函数示例:
# file : <项目名>/urls.py
# 以下示例匹配
# http://127.0.0.1:8000/person/xiaoming/20
# http://127.0.0.1:8000/person/xiaohong/29
# http://127.0.0.1:8000/person/xiaolan/9
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^person/(?P\w+)/(?P\d{1,2})' ,views.person_view),
]
练习:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-90y8L828-1619273946661)(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对象
当浏览者访问一个网页时,浏览者的浏览器会向网页所在服务器发出请求。当浏览器接收并显示网页前,此网页所在的服务器会返回一个包含HTTP状态码的信息头用以响应浏览器的请求。
HTTP状态码的英文为HTTP Status Code。
下面是常见的HTTP状态码:
HTTP状态码分类
HTTP状态码由三个十进制数字组成,第一个十进制数字定义了状态码的类型,后两个数字没有分类的作用。HTTP状态码共分为5种类型:
分类 | 分类描述 |
---|---|
1** | 信息,服务器收到请求,需要请求者继续执行操作 |
2** | 成功,操作被成功接收并处理 |
3** | 重定向,需要进一步的操作以完成请求 |
4** | 客户端错误,请求包含语法错误或无法完成请求 |
5** | 服务器错误,服务器在处理请求的过程中发生了错误 |
Django中的响应对象HttpResponse:
构造函数格式:
HttpResponse(content=响应体, content_type=响应体数据类型, status=状态码)
作用:
参数:
'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)是指多用途互联网邮件扩展类型。
HttpResponse 子类
类型 | 作用 | 状态码 |
---|---|---|
HttpResponseRedirect | 重定响 | 302 |
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
一般查询字符串的大小会受到浏览器的的限制(不建议超过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指定的服务器相关位置
key1=value1&key2=value2&key3=value3
在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>
注意事项:
1,若启动django时【python3 manage.py runserver】报如下错误:
Error: That port is already in use.
解决方案:
分析:当前有其他进程占用8000端口,
方案1:ps aux|grep 'manage' -> sudo kill -9 进程id
方案2:更换端口启动 python3 manage.py runserver 8080
{‘CLUTTER_IM_MODULE’: ‘xim’, ‘LS_COLORS’: ‘rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:mi=00:su=37;41:sg=30;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32:.tar=01;31:.tgz=01;31:.arc=01;31:.arj=01;31:.taz=01;31:.lha=01;31:.lz4=01;31:.lzh=01;31:.lzma=01;31:.tlz=01;31:.txz=01;31:.tzo=01;31:.t7z=01;31:.zip=01;31:.z=01;31:.Z=01;31:.dz=01;31:.gz=01;31:.lrz=01;31:.lz=01;31:.lzo=01;31:.xz=01;31:.zst=01;31:.tzst=01;31:.bz2=01;31:.bz=01;31:.tbz=01;31:.tbz2=01;31:.tz=01;31:.deb=01;31:.rpm=01;31:.jar=01;31:.war=01;31:.ear=01;31:.sar=01;31:.rar=01;31:.alz=01;31:.ace=01;31:.zoo=01;31:.cpio=01;31:.7z=01;31:.rz=01;31:.cab=01;31:.wim=01;31:.swm=01;31:.dwm=01;31:.esd=01;31:.jpg=01;35:.jpeg=01;35:.mjpg=01;35:.mjpeg=01;35:.gif=01;35:.bmp=01;35:.pbm=01;35:.pgm=01;35:.ppm=01;35:.tga=01;35:.xbm=01;35:.xpm=01;35:.tif=01;35:.tiff=01;35:.png=01;35:.svg=01;35:.svgz=01;35:.mng=01;35:.pcx=01;35:.mov=01;35:.mpg=01;35:.mpeg=01;35:.m2v=01;35:.mkv=01;35:.webm=01;35:.ogm=01;35:.mp4=01;35:.m4v=01;35:.mp4v=01;35:.vob=01;35:.qt=01;35:.nuv=01;35:.wmv=01;35:.asf=01;35:.rm=01;35:.rmvb=01;35:.flc=01;35:.avi=01;35:.fli=01;35:.flv=01;35:.gl=01;35:.dl=01;35:.xcf=01;35:.xwd=01;35:.yuv=01;35:.cgm=01;35:.emf=01;35:.ogv=01;35:.ogx=01;35:.aac=00;36:.au=00;36:.flac=00;36:.m4a=00;36:.mid=00;36:.midi=00;36:.mka=00;36:.mp3=00;36:.mpc=00;36:.ogg=00;36:.ra=00;36:.wav=00;36:.oga=00;36:.opus=00;36:.spx=00;36:.xspf=00;36:’, ‘LC_MEASUREMENT’: ‘zh_CN.UTF-8’, ‘LESSCLOSE’: ‘/usr/bin/lesspipe %s %s’, ‘LC_PAPER’: ‘zh_CN.UTF-8’, ‘LC_MONETARY’: ‘zh_CN.UTF-8’, ‘XDG_MENU_PREFIX’: ‘gnome-’, ‘LANG’: ‘zh_CN.UTF-8’, ‘DISPLAY’: ‘:0’, ‘GNOME_SHELL_SESSION_MODE’: ‘ubuntu’, ‘COLORTERM’: ‘truecolor’, ‘USERNAME’: ‘tarena’, ‘XDG_VTNR’: ‘2’, ‘SSH_AUTH_SOCK’: ‘/run/user/1000/keyring/ssh’, ‘MANDATORY_PATH’: ‘/usr/share/gconf/ubuntu.mandatory.path’, ‘LC_NAME’: ‘zh_CN.UTF-8’, ‘XDG_SESSION_ID’: ‘2’, ‘USER’: ‘tarena’, ‘DESKTOP_SESSION’: ‘ubuntu’, ‘QT4_IM_MODULE’: ‘fcitx’, ‘TEXTDOMAINDIR’: ‘/usr/share/locale/’, ‘GNOME_TERMINAL_SCREEN’: ‘/org/gnome/Terminal/screen/1f09273e_af23_466d_a8e4_0363dd9ba68a’, ‘DEFAULTS_PATH’: ‘/usr/share/gconf/ubuntu.default.path’, ‘PWD’: ‘/home/tarena/1907/django/day01/mysite1’, ‘HOME’: ‘/home/tarena’, ‘TEXTDOMAIN’: ‘im-config’, ‘SSH_AGENT_PID’: ‘2888’, ‘QT_ACCESSIBILITY’: ‘1’, ‘XDG_SESSION_TYPE’: ‘x11’, ‘XDG_DATA_DIRS’: ‘/usr/share/ubuntu:/usr/local/share:/usr/share:/var/lib/snapd/desktop’, ‘XDG_SESSION_DESKTOP’: ‘ubuntu’, ‘LC_ADDRESS’: ‘zh_CN.UTF-8’, ‘GJS_DEBUG_OUTPUT’: ‘stderr’, ‘LC_NUMERIC’: ‘zh_CN.UTF-8’, ‘GTK_MODULES’: ‘gail:atk-bridge’, ‘WINDOWPATH’: ‘2’, ‘VTE_VERSION’: ‘5202’, ‘TERM’: ‘xterm-256color’, ‘SHELL’: ‘/bin/bash’, ‘QT_IM_MODULE’: ‘fcitx’, ‘XMODIFIERS’: ‘@im=fcitx’, ‘IM_CONFIG_PHASE’: ‘2’, ‘XDG_CURRENT_DESKTOP’: ‘ubuntu:GNOME’, ‘GPG_AGENT_INFO’: ‘/run/user/1000/gnupg/S.gpg-agent:0:1’, ‘GNOME_TERMINAL_SERVICE’: ‘:1.73’, ‘XDG_SEAT’: ‘seat0’, ‘SHLVL’: ‘1’, ‘LANGUAGE’: ‘zh_CN:zh:en_US:en’, ‘LC_TELEPHONE’: ‘zh_CN.UTF-8’, ‘GDMSESSION’: ‘ubuntu’, ‘GNOME_DESKTOP_SESSION_ID’: ‘this-is-deprecated’, ‘LOGNAME’: ‘tarena’, ‘DBUS_SESSION_BUS_ADDRESS’: ‘unix:path=/run/user/1000/bus’, ‘XDG_RUNTIME_DIR’: ‘/run/user/1000’, ‘XAUTHORITY’: ‘/run/user/1000/gdm/Xauthority’, ‘XDG_CONFIG_DIRS’: ‘/etc/xdg/xdg-ubuntu:/etc/xdg’, ‘PATH’: ‘/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin’, ‘LC_IDENTIFICATION’: ‘zh_CN.UTF-8’, ‘GJS_DEBUG_TOPICS’: ‘JS ERROR;JS LOG’, ‘SESSION_MANAGER’: ‘local/tedu:@/tmp/.ICE-unix/2797,unix/tedu:/tmp/.ICE-unix/2797’, ‘LESSOPEN’: ‘| /usr/bin/lesspipe %s’, ‘GTK_IM_MODULE’: ‘fcitx’, ‘LC_TIME’: ‘zh_CN.UTF-8’, ‘_’: ‘/usr/bin/python3’, ‘OLDPWD’: ‘/home/tarena/1907/django/day01/mysite1/mysite1’, ‘DJANGO_SETTINGS_MODULE’: ‘mysite1.settings’, ‘TZ’: ‘Asia/Shanghai’, ‘RUN_MAIN’: ‘true’, ‘SERVER_NAME’: ‘localhost’, ‘GATEWAY_INTERFACE’: ‘CGI/1.1’, ‘SERVER_PORT’: ‘8000’, ‘REMOTE_HOST’: ‘’, ‘CONTENT_LENGTH’: ‘’, ‘SCRIPT_NAME’: ‘’, ‘SERVER_PROTOCOL’: ‘HTTP/1.1’, ‘SERVER_SOFTWARE’: ‘WSGIServer/0.2’, ‘REQUEST_METHOD’: ‘GET’, ‘PATH_INFO’: ‘/page1’, ‘QUERY_STRING’: ‘a=1&b=2’, ‘REMOTE_ADDR’: ‘127.0.0.1’, ‘CONTENT_TYPE’: ‘text/plain’, ‘HTTP_HOST’: ‘127.0.0.1:8000’, ‘HTTP_USER_AGENT’: ‘Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:69.0) Gecko/20100101 Firefox/69.0’, ‘HTTP_ACCEPT’: ‘text/html,application/xhtml+xml,application/xml;q=0.9,/;q=0.8’, ‘HTTP_ACCEPT_LANGUAGE’: ‘zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2’, ‘HTTP_ACCEPT_ENCODING’: ‘gzip, deflate’, ‘HTTP_CONNECTION’: ‘keep-alive’, ‘HTTP_COOKIE’: ‘csrftoken=Tu8X9qMe0PKsVScSJnONTl6lO24hVZYE3H9FpaF7LJtZRvkrHLvE4Z2q7Fv2W7T3’, ‘HTTP_UPGRADE_INSECURE_REQUESTS’: ‘1’, ‘wsgi.input’: <_io.BufferedReader name=5>, ‘wsgi.errors’: <_io.TextIOWrapper name=’’ mode=‘w’ encoding=‘UTF-8’>, ‘wsgi.version’: (1, 0), ‘wsgi.run_once’: False, ‘wsgi.url_scheme’: ‘http’, ‘wsgi.multithread’: True, ‘wsgi.multiprocess’: False, ‘wsgi.file_wrapper’: