Django框架的介绍及基本配置


Django框架的介绍

Django的官网

官方网址: http://www.djangoproject.com

中文文档(第三方):

https://yiyibooks.cn/

http://djangobook.py3k.cn/

Django的离线文档

解压缩数据包 django-docs-1.11-en.zip

用浏览器打开 django-docs-1.11-en/index.html

Django的安装

查看已安装的版本

>>>importdjango

>>>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

用wheel离线安装

下载安装包:

pip3 download -d /home/tarena/django_packs django==1.11.8

安装离线包

$ pip3 install Django-1.11.8.whl

Django的卸载

$ pip3 uninstall django

Django 的开发环境

Django 1.11.x 支持 Python 2.7, 3.4, 3.5 和 3.6(长期支持版本 LTS)

注: Django 1.11.x 不支持 Python 3.7


Django框架开发

创建项目的指令

$ django-admin startproject 项目名称

如:

$ django-admin startproject mysite1

运行

$ cdmysite1

$ python3manage.py runserver

# 或

$ python3manage.py runserver5000# 指定只能本机使用127.0.0.1的5000端口访问本机

Django项目的目录结构

示例:

$ django-adminstartproject mysite1

$ treemysite1/

mysite1/

├── manage.py

└── mysite1

   ├── __init__.py

   ├── settings.py

   ├── urls.py

   └── wsgi.py

1directory,5files

项目目录结构解析:

manage.py

此文件是项目管理的主程序,在开发阶段用于管理整个项目的开发运行的调式

manage.py 包含项目管理的子命令, 如:

python3 manage.py runserver 启动服务

python3 manage.py startapp 创建应用

python3 manage.py migrate 数据库迁移

...

mysite1 项目包文件夹

项目包的主文件夹(默认与项目名称一致)

__init__.py

包初始化文件,当此项目包被导入(import)时此文件会自动运行

wsgi.py

WSGI 即 Web Server Gateway Interface

WEB服务网关接口的配置文件,仅部署项目时使用

urls.py

项目的基础路由配置文件,所有的动态路径必须先走该文件进行匹配

settings.py

Django项目的配置文件, 此配置文件中的一些全局变量将为Django框架的运行传递一些参数

setting.py 配置文件,启动服务时自动调用,

此配置文件中也可以定义一些自定义的变量用于作用全局作用域的数据传递

settings.py 文件介绍

https://docs.djangoproject.com/en/1.11/ref/settings/

BASE_DIR

用于绑定当前项目的绝对路径(动态计算出来的), 所有文件都可以依懒此路径

DEBUG

用于配置Django项目的启用模式, 取值:

True 表示开发环境中使用 调试模式(用于开发中)

False 表示当前项目运行在生产环境中(不启用调试)

ALLOWED_HOSTS

设置允许访问到本项目的网络地址列表,取值:

[] 空列表,表示只有请求头中host为127.0.0.1, localhost能访问本项目

['*'],表示任何请求头的host都能访问到当前项目

['192.168.1.3', '127.0.0.1'] 表示只有当前两个host头的值能访问当前项目

注意:

如果要在局域网其它主机也能访问此主机,启动方式应使用如下模式:

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

用于配置根级 url 配置 'mysite1.urls'

如:

ROOT_URLCONF = 'mysite1.urls'

注: 此模块可以通过 from django.conf import settings 导入和使用

URL 介绍

url 即统一资源定位符 Uniform Resource Locator

作用:

用来表示互联网上某个资源的地址。

说明:

互联网上的每个文件都有一个唯一的URL,它包含的信息指出文件的位置以及浏览器应该怎么处理它。

URL的一般语法格式为:

protocol :// hostname[:port] / path [?query][#fragment]

如:

http://tts.tmooc.cn/video/showVideo?menuId=657421&version=AID201908#subject

说明:

protocol(协议)

http 通过 HTTP 访问该资源。 格式 HTTP://

https 通过安全的 HTTPS 访问该资源。 格式 HTTPS://

file 资源是本地计算机上的文件。格式: file:///

...

hostname(主机名)

是指存放资源的服务器的域名系统(DNS) 主机名、域名 或 IP 地址。

port(端口号)

整数,可选,省略时使用方案的默认端口;

各种传输协议都有默认的端口号,如http的默认端口为80。

path(路由地址)

由零或多个“/”符号隔开的字符串,一般用来表示主机上的一个目录或文件地址。路由地址决定了服务器端如何处理这个请求

query(查询)

可选,用于给动态网页传递参数,可有多个参数,用“&”符号隔开,每个参数的名和值用“=”符号隔开。

fragment(信息片断)

字符串,用于指定网络资源中的片断。例如一个网页中有多个名词解释,可使用fragment直接定位到某一名词解释。

注: [] 代表其中的内容可省略

视图函数(view)

视图函数是用于接收一个浏览器请求并通过HttpResponse对象返回数据的函数。此函数可以接收浏览器请求并根据业务逻辑返回相应的内容给浏览器

视图处理的函数的语法格式:

defxxx_view(request[,其它参数...]):

returnHttpResponse对象

参数:

request用于绑定HttpRequest对象,通过此对象可以获取浏览器的参数和数据

示例:

视图处理函数 views.py

# file : <项目名>/views.py

fromdjango.httpimportHttpResponse

defpage1_view(request):

html="<h1>这是第1个页面</h1>"

returnHttpResponse(html)

Django 中的路由配置

settings.py 中的ROOT_URLCONF 指定了主路由配置列表urlpatterns的文件位置

urls.py 主路由配置文件

# file : <项目名>/urls.py

urlpatterns= [

url(r'^admin/',admin.site.urls),

...# 此处配置主路由

]

urlpatterns 是一个路由-视图函数映射关的列表,此列表的映射关系由url函数来确定

url() 函数

用于描述路由与视图函数的对应关系

模块

from django.conf.urls import url

语法:

url(regex, views, name=None)

参数:

regex: 字符串类型,匹配的请求路径,允许是正则表达式

views: 指定路径所对应的视图处理函数的名称

name: 为地址起别名,在模板中地址反向解析时使用

每个正则表达式前面的r表示'\'不转义的原始字符串


练习

建立一个小网站:

输入网址: http://127.0.0.1:8000, 在网页中输出 : 这是我的首页

输入网址: http://127.0.0.1:8000/page1, 在网页中输出 : 这是编号为1的网页

输入网址: http://127.0.0.1:8000/page2, 在网页中输出 : 这是编号为2的网页

提示: 主页路由的正则是  r'^$'

思考

建立如上一百个网页该怎么办?

带有分组的路由和视图函数

在视图函数内,可以用正则表达式分组 () 提取参数后用函数位置传参传递给视图函数

一个分组表示一个参数,多个参数需要使用多个分组,并且使用个/隔开

如:

http://127.0.0.1:8000/year/2018

http://127.0.0.1:8000/year/2019

http://127.0.0.1:8000/year/????  # 四位数字

练习:

定义一个路由的格式为:

http://127.0.0.1:8000/整数/操作字符串/整数

从路由中提取数据,做相应的操作后返回给浏览器

如:

输入: 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 的正则表达式中可以使用命名分组(捕获分组)

说明:

在视图函数内,可以用正则表达式分组 (?P<name>pattern) 提取参数后用函数关键字传参传递给视图函数

示例:

路由配置文件

# 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<name>\w+)/(?P<age>\d{1,2})',views.person_view),

]

练习:

访问地址:

http://127.0.0.1:8000/birthday/四位数字/一到两位数字/一到两位数字

http://127.0.0.1:8000/birthday/一到两位数字/一到两位数字/四位数字

最终输出: 生日为: xxxx年xx月xx日

如:输入网址: http://127.0.0.1:8000/birthday/2015/12/11显示为: 生日为:2015年12月11日输入网址: http://127.0.0.1:8000/birthday/2/28/2008显示为: 生日为:2008年2月28日


HTTP协议的请求和响应

请求是指浏览器端通过HTTP协议发送给服务器端的数据

响应是指服务器端接收到请求后做相应的处理后再回复给浏览器端的数据

HTTP 请求

根据HTTP标准,HTTP请求可以使用多种请求方法。

HTTP1.0定义了三种请求方法: GET, POST 和 HEAD方法(最常用)

HTTP1.1新增了五种请求方法:OPTIONS, PUT, DELETE, TRACE 和 CONNECT 方法。

HTTP1.1 请求详述

序号方法描述

1GET请求指定的页面信息,并返回实体主体。

2HEAD类似于get请求,只不过返回的响应中没有具体的内容,用于获取报头

3POST向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中。POST请求可能会导致新的资源的建立和/或已有资源的修改。

4PUT从客户端向服务器传送的数据取代指定的文档的内容。

5DELETE请求服务器删除指定的页面。

6CONNECTHTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器。

7OPTIONS允许客户端查看服务器的性能。

8TRACE回显服务器收到的请求,主要用于测试或诊断。

HttpRequest对象

视图函数的第一个参数是HttpRequest对象

服务器接收到http协议的请求后,会根据请求数据报文创建HttpRequest对象

HttpRequest属性

path_info: URL字符串

method:字符串,表示HTTP请求方法,常用值:'GET'、'POST'

encoding:字符串,表示提交的数据的编码方式

如果为None则表示使用浏览器的默认设置,一般为'utf-8'

这个属性是可写的,可以通过修改它来修改访问表单数据使用的编码,接下来对属性的任何访问将使用新的encoding值

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地址

HTTP 响应

当浏览者访问一个网页时,浏览者的浏览器会向网页所在服务器发出请求。当浏览器接收并显示网页前,此网页所在的服务器会返回一个包含HTTP状态码的信息头用以响应浏览器的请求。

HTTP状态码的英文为HTTP Status Code。

下面是常见的HTTP状态码:

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)是指多用途互联网邮件扩展类型。

HttpResponse 子类

类型作用状态码

HttpResponseRedirect重定响302

HttpResponseNotModified未修改304

HttpResponseBadRequest错误请求400

HttpResponseNotFound没有对应的资源404

HttpResponseForbidden请求被禁止403

HttpResponseServerError服务器错误500


GET方式传参

GET请求方式中可以通过查询字符串(Query String)将数据传递给服务器   

URL 格式: xxx?参数名1=值1&参数名2=值2...

如: http://127.0.0.1:8000/page1?a=100&b=200

服务器端接收参数

判断 request.method 的值判断请求方式是否是get请求

ifrequest.method=='GET':

处理GET请求时的业务逻辑

else:

处理其它请求的业务逻辑

获取客户端请求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']  # Error

能够产生get请求方式的场合

地址栏手动输入, 如: http://127.0.0.1:8000/mypage?a=100&b=200

<a href="地址?参数=值&参数=值">

form表单中的method为get

<formmethod='get'action="/user/login">

姓名:<inputtype="text"name="uname">

</form>

一般查询字符串的大小会受到浏览器的的限制(不建议超过2048字节)

练习:

访问地址:http://127.0.0.1:8000/sum?start=整数&stop=整数&step整=字

输出结果为sum(range(start, step, stop)) 和:

如:

输入网址: http://127.0.0.1:8000/sum?start=1&stop=101&step=1

页面显示: 结果: 5050

输入网址: http://127.0.0.1:8000/sum?stop=101&step=2

页面显示: 结果: 2550

输入网址: http://127.0.0.1:8000/sum?start=1&stop=101&step=2

页面显示: 结果: 2500

练习:

访问地址:http://127.0.0.1:8000/birthday?year=四位整数&month=整数&day=整数

最终输出: 生日为: xxxx年xx月xx日

如:

输入网址: http://127.0.0.1:8000/birthday?year=2015&month=12&day=11

显示为: 生日为:2015年12月11日


POST传递参数

客户端通过表单等POST请求将数据传递给服务器端,如:

<formmethod='post'action="/login">

姓名:<inputtype="text"name="username">

<inputtype='submit'value='登陆'>

</form>

服务器端接收参数

通过 request.method 来判断是否为POST请求,如:

ifrequest.method=='POST':

处理POST请求的数据并响应

else:

处理非POST请求的响应

使用post方式接收客户端数据

方法

request.POST['参数名']# request.POST 绑定QueryDict

request.POST.get('参数名','')

request.POST.getlist('参数名')

取消csrf验证,否则Django将会拒绝客户端发来的POST请求

取消 csrf 验证

删除 settings.py 中 MIDDLEWARE 中的 CsrfViewsMiddleWare 的中间件

MIDDLEWARE= [

   ...

# 'django.middleware.csrf.CsrfViewMiddleware',

   ...

]

form 表单的name属性

在form表单控件提交数据时,会自动搜索本表单控件内部的子标签的name属性及相应的值,再将这些名字和值以键-值对的形式提交给action指定的服务器相关位置

在form内能自动搜集到的name属性的标签的控件有

<inputname='xxx'>

<selectname='yyy'></select>

<textareaname='zzz'></textarea>

如:

<formaction="/page1"method="POST">

<inputname="title"type="text"value="请输入">

<selectname="gender">

<optionvalue=1>男</option>

<optionvalue=0>女</option>

</select>

<textareaname="comment"rows="5"cols="10">附言...</textarea>

<inputtype="submit"value="提交">

</form>

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352