Django框架(八):视图(一) URLconf、视图

Django框架(八):视图(一) URLconf、视图

1. 视图

视图的功能就是接收请求,进行处理,与M和T进行交互,返回应答。

返回html内容HttpResponse,也可能重定向redirect,还可以返回json数据。

1.1 URLconf

1.1.1 配置

用户通过在浏览器的地址栏中输入网址请求网站,对于Django开发的网站,由哪一个视图进行处理请求,是由url匹配找到的。

在Urltest/settings.py中通过ROOT_URLCONF指定url配置,默认已经有此配置。

打开Urltest/urls.py可以看到默认配置。

在Urltest/urls.py中进行包含配置,在各自应用中创建具体配置。

定义urlpatterns列表,存储url()对象,这个名称是固定的。

urlpatterns中的每个正则表达式在第一次访问它们时被编译,这使得运行很快。

1.1.2 语法

url()对象,被定义在django.conf.urls包中,有两种语法结构。

语法1:一般在自定义应用中创建一个urls.py来定义url。

这种语法用于Urltest/urls.py中,目的是将应用的urls配置到应用内部,数据更清晰并且易于维护。

url(正则,include("应用.urls"))

例如booktest中的urls。

url(r"^",include("booktest.urls")),

在booktest目录下创建urls.py文件。

语法2:指定URL和视图函数的对应关系。

在应用内部创建urls.py文件,指定请求地址与视图的对应关系。

url(正则,"视图函数名称")

例如在booktest/urls.py中创建首页的url。

from django.conf.urls import url
from booktest import views
urlpatterns=[
    url(r"^$",views.index),
]

在booktest/views.py中创建视图index。 

from django.shortcuts import render
from django.http import HttpResponse

def index(request):
    return HttpResponse("视图函数index")

正则部分推荐使用r,表示字符串不转义,这样在正则表达式中使用只写一个就可以。 说明2:不能在开始加反斜杠,推荐在结束加反斜杠。

正确:index/
正确:index
错误:/index
错误:/index/

1.1.3 获取值

请求的url被看做是一个普通的python字符串,进行匹配时不包括域名、get或post参数。 如请求地址如下:

http://127.0.0.1:8000/delete1/?a=10

去除掉域名和参数部分,并将最前面的/去除后,只剩下如下部分与正则匹配。

delete1/

打开booktest/urls.py文件,定义与这个地址匹配的url如下:

url(r"^deleted+/$",views.show_arg),

在booktest/views.py中创建视图show_arg。

def show_arg(request):
    return HttpResponse("show_arg")

启动服务器,输入上面的网址,浏览器中效果如下图。

可以在匹配过程中从url中捕获参数,每个捕获的参数都作为一个普通的python字符串传递给视图。

获取值需要在正则表达式中使用小括号,分为两种方式:

  • 位置参数
  • 关键字参数

两种参数的方式不要混合使用,在一个正则表达式中只能使用一种参数方式。

方式1:位置参数

直接使用小括号,通过位置参数传递给视图。

为了提取参数,修改上面的正则表达式如下:

url(r"^delete(d+)/$",views.show_arg),

修改视图show_arg如下:

参数的名字是任意的如a1、b8,尽量做到见名知意。

def show_arg(request,id):
    return HttpResponse("show arg %s"%id)

刷新浏览器页面,效果如下图:

在地址栏输入如下地址: 

方式2:关键字参数

在正则表达式部分为组命名。 

修改正则表达式如下:

其中?P部分表示为这个参数定义的名称为id,可以是其它名称,起名做到见名知意。

url(r"^delete(?P<id1>d+)/$",views.show_arg),

修改视图show_arg如下:

视图show_arg此时必须要有一个参数名为id1,否则报错。

def show_arg(request,id1):
    return HttpResponse("show arg %s"%id1)

刷新浏览器页面,效果如下图:

1.2 视图

视图就是python中的函数,视图一般被定义在"应用/views.py"文件中,此例中为"booktest/views.py"文件。视图必须返回一个HttpResponse对象或子对象作为响应。响应可以是一张网页的HTML内容,一个重定向,一个404错误等。

1.2.1 url匹配的过程

url:http://127.0.0.1:8000/aindex?a=1

1) 去除域名和后面的参数,剩下/aindex,再把前面的/去掉,剩下aindex。

2) 拿aindex先到项目的url.py文件中进行从上到下的匹配,匹配成功之后执行后面对应的处理动作,就是把匹配成功的部分a字符去除,然后拿剩下的部分index到应用的urls.py文件中再进行从上到下的匹配。

3) 如果匹配成功则调用相应的视图产生内容返回给客户端。如果匹配失败则产生404错误。

1.2.2 内置错误视图

Django内置处理HTTP错误的视图,主要错误及视图包括: 

  • 404错误:page not found视图
  • 500错误:server error视图

如果想看到错误视图而不是调试信息,需要修改djangotest/setting.py文件的DEBUG项。

DEBUG = False
ALLOWED_HOSTS = ["*", ]

(1) 404错误及视图

将请求地址进行url匹配后,没有找到匹配的正则表达式,则调用404视图,这个视图会调用404.html的模板进行渲染。视图传递变量request_path给模板,表示导致错误的URL。

在templates中创建404.html。

定义代码如下: 

<html>
<head>
    <title></title>
</head>
<body>
找不到了
<hr/>
{{request_path}}
</body>
</html>

在浏览器中输入如下网址:

http://127.0.0.1:8000/test/

运行效果如下图:

(2) 500错误及视图 

在视图中代码运行报错会发生500错误,调用内置错误视图,使用templates/500.html模板渲染。

视图处理过程如下图: