>>> import django
>>> print(django.VERSION)
(2, 2, 12, 'final', 0)
在线安装
$ sudo pip3 install django 安装 django 的最新版本
或
$ sudo pip3 install django[==版本] 安装 django 的指定版本
如:
`$ sudo pip3 install django==2.2.12
离线安装
下载安装包:
安装离线包
$ tar -xvf Django-2.2.12.tar.gz
$ cd Django-2.2.12
$ sudo python3 setup.py install
Django 2.2.12 支持 3.5,3.6,3.7,3.8
$ django-admin startproject 项目名称
如: $ django-admin startproject mysite1
运行
$ cd mysite1
$ python3 manage.py runserve
# 或
$ 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
此文件是项目管理的主程序,在开发阶段用于管理整个项目的开发运行的调式
manage.py 包含项目管理的子命令,如:
mysite1 项目文件夹
项目包的主文件夹 (默认与项目名称一致)
__init__.py
wsgi.py
urls.py
settings.py
settings.py
文件介绍https://docs.djangoproject.com/en/2.2/ref/settings/
BASE_DIR
DEBUG
调试模式
(用于开发中)生产环境中
(不启用调试) ALLOWED_HOSTS
[]
空列表,表示只有host请求头为127.0.0.1
, localhost
能访问本项目 - DEBUG = True时生效['*']
,表示任何请求头的host都能访问到当前项目['192.168.1.3', '127.0.0.1']
表示只有当前两个host头的值能访问当前项目python3 manage.py runserver 0.0.0.0:5000
指定网络设备如果内网环境下其他主机想正常访问该站点,需加ALLOWED_HOSTS = ['内网ip']
INSTALLED_APP
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 Locato
作用:
说明:
URL 的一般语法格式为:
protocol :// hostname[:port] / path [?query][#fragment]
如:
http://tts.tmooc.cn/video/showVideo?menuId=657421&version=AID201908#subject
说明:
http 通过 HTTP 访问该资源。 格式 HTTP://
https 通过安全的 HTTPS 访问该资源。 格式 HTTPS://
file 资源是本地计算机上的文件。格式: file:///
…
是指存放资源的服务器的域名系统 (DNS) 主机名、域名 或 IP 地址。
整数,可选,省略时使用方案的默认端口;
各种传输协议都有默认的端口号,如 http 的默认端口为 80,https 是 443。
由零或多个 “/” 符号隔开的字符串,一般用来表示主机上的一个目录或文件地址。路由地址决定了服务器端如何处理这个请求
可选,用于给动态网页传递参数,可有多个参数,用 “&” 符号隔开,每个参数的名和值用 “=” 符号隔开。
字符串,用于指定网络资源中的片断。例如一个网页中有多个名词解释,可使用 fragment 直接定位到某一名词解释。
注: [] 代表其中的内容可省略
浏览器 http://127.0.0.1:8000/page/2003/
# 主路由-urls.py样例:
from django.urls import path
from . import views
urlpatterns = [
path('admin/', admin.site.urls)
path('page/2003/', views.page_2003),
path('page/2004/', views.page_2004),
]
def xxx_view(request[, 其它参数...]):
return HttpResponse对象
request 用于绑定 HttpRequest 对象,通过此对象可以获取浏览器的参数和数据
HttpResponse 的对象;Django 会提供一系列的 response 对象;
views.py
下的视图处理函数
# file : <项目同名文件夹下>/views.py
from django.http import HttpResponse
def page1_view(request):
html = "<h1>这是第1个页面</h1>"
return HttpResponse(html)
settings.py
中的 ROOT_URLCONF
指定了主路由配置列表 urlpatterns 的文件位置
urls.py
主路由配置文件
# file : <项目同名文件夹>/urls.py
urlpatterns = [
path('admin/', admin.site.urls),
... # 此处配置主路由
]
from django.urls import path
思考:建立如上一百个网页该怎么办?
语法: <转换器类型:自定义名>
作用:若转换器类型匹配到对应类型的数据,则将数据按照关键字传参的方式传递给视图函数
转换器 | 效果 | 案例 |
---|---|---|
str | 匹配除了 '/' 之外的非空字符串 | "v1/users/<str:username>"匹配 /v1/users/guoxiaonao |
int | 匹配0或任何正整数。返回一个 int | “page/<int:page>” 匹配 /page/100 |
slug | 匹配任意由 ASCII 字母或数字以及连字符和下划线组成的短标签 | “detail/<slug:sl>” 匹配 /detail/this-is-django |
path | 匹配非空字段,包括路径分隔符 '/' | "v1/users/<path:ph>"匹配 /v1/goods/a/b/c |
re_path(reg, view, name=xxx)
正则表达式为命名分组模式 (?P<name>pattern) ;匹配提取参数后用关键字传参方式传递给视图函数
路由配置文件
# file : <项目同名文件夹>/urls.py
# 以下示例匹配
# 可匹配 http://127.0.0.1:8000/20/mul/40
# 不可匹配 http://127.0.0.1:8000/200/mul/400
urlpatterns = [
path('admin/', admin.site.urls),
re_path(r'^(?P<x>\d{1,2})/(?P<op>\w+)/(?P<y>\d{1,2})$',views.cal_view),
POST /v1/tokens HTTP/1.1 -> 起始行
Host: 127.0.0.1:8000 -> headers
User-Agent: Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:74.0) Gecko/20100101 Firefox/74.0
Accept: */*
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
Accept-Encoding: gzip, deflate
Content-Type: application/json
Content-Length: 58
Origin: http://127.0.0.1:7000
Connection: keep-alive
Referer: http://127.0.0.1:7000/dadashop/templates/login.html
{"username":"guoxiaonao"} -> body
HTTP/1.0 200 OK -> 起始行
Date: Sat, 21 Mar 2020 09:44:15 GMT -> headers
Server: WSGIServer/0.2 CPython/3.6.8
Content-Type: application/json
X-Frame-Options: SAMEORIGIN
Content-Length: 217
Vary: Origin
Access-Control-Allow-Origin: *
{"code": 200, "username": "guoxiaonao"} -> body
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)是指多用途互联网邮件扩展类型。
if request.method == 'GET':
处理GET请求时的业务逻辑
elif request.method == 'POST':
处理POST请求的业务逻辑
else:
其他请求业务逻辑
GET 请求动作,一般用于向服务器获取数据
能够产生 GET 请求的场景:
<form method='get' action="/user/login">
姓名:<input type="text" name="uname">
</form>
GET 请求方式中,如果有数据需要传递给服务器,通常会用查询字符串 (Query String) 传递 【注意:不要传递敏感数据】
如: http://127.0.0.1:8000/page1?a=100&b=200
获取客户端请求 GET 请求提交的数据
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'] # Erro
POST 请求动作,一般用于向服务器提交大量数据
客户端通过表单等 POST 请求将数据传递给服务器端,如:
<form method='post' action="/login">
姓名:<input type="text" name="username">
<input type='submit' value='登陆'>
</form>
form 表单的 name 属性
<input name='xxx'>
<select name='yyy'></select>
<textarea name='zzz'></textarea>
服务器端接收参数
if request.method == 'POST':
处理POST请求的数据并响应
else:
处理非POST 请求的响应
使用 post 方式接收客户端数据
request.POST['参数名'] # request.POST 绑定QueryDict
request.POST.get('参数名','')
request.POST.getlist('参数名')
取消 csrf 验证,否则 Django 将会拒绝客户端发来的 POST 请求
禁止掉 settings.py 中 MIDDLEWARE 中的 CsrfViewsMiddleWare 的中间件
MIDDLEWARE = [
...
# 'django.middleware.csrf.CsrfViewMiddleware',
...
]