Django如何将URL映射到视图

前言

URLconf 就像是 Django 所支撑网站的目录。它的本质是 URL 模式以及要为该 URL 模式调用的视图函数之间的映射表。你就是以这种方式告诉 Django,对于这个 URL 调用这段代码,对于那个 URL 调用那段代码。但必须记住的是视图函数必须位于 Python 搜索路径之中。

Python 搜索路径

Python 搜索路径 就是使用 import 语句时, Python 所查找的系统目录清单。

举例来说,假定你将 Python 路径设置为['','/usr/lib/python2.4/site-packages','/home/username/djcode/'] 。如果执行代码

from foo import bar , Python 将会首先在当前目录查找 foo.py 模块( Python 路径第一项的空字符串表示当前目录)。如果文件不存在, Python 将查找/usr/lib/python2.4/site-packages/foo.py 文件。

如果文件也不存在,它将尝试/home/username/djcode/foo.py 。

最后,如果这个文件还不存在,它将引发ImportError异常。

如果对了解 Python 搜索路径值感兴趣,可以启动 Python 交互式解释程序,输入 importsys ,接着输入 print sys.path

通常,你不必关心 Python 搜索路径的设置。 Python 和 Django 会在后台自动帮你处理好。

(如果有兴趣了解的话, Python 搜索路径的设置工作是 manage.py 文件的职能之一。 )

执行 django-admin.py startproject 时,该脚本会自动为你建了一份 URLconf(即

urls.py 文件)。让我们编辑一下这份文件。缺省情况下它是下面这个样子:

from django.conf.urls import url

from django.contrib import admin

import view

urlpatterns = [

url(r'^hello', view.djangoStudy),

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

url(r'^index/$',view.index)

]

# urlpatterns = [

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

# ]

当前应该注意是 urlpatterns 变量, Django 期望能从 ROOT_URLCONF 模块中找到它。该变量定义了 URL 以及用于处理这些 URL 的代码之间的映射关系

r'^index/$' 中的 r 表示'^index/$' 是一个原始字符串。这样一来就可以避免 正则表达式有过多的转义字符。

不必在 '^index/$'前加斜杠(/)来匹配 /index/ , 因为 Django 会自动在每个表 达式前添加一个斜杠。乍看起来,这好像有点奇怪,但是 URLconfs 可能由其它的 URLconfs 所引用, 所以不加前面的斜杠可让事情简单一些。

上箭头 ^ 和美元符号 $ 符号非常重要。上箭头要求表达式对字符串的头部进行匹配,美元符号则要求表达式对字符串的尾部进行匹配。

最好还是用范例来说明一下这个概念。如果我们用 '^index/' (结尾没有$), 那么以 index/开始的 任意 URL 都会匹配,比如 /index/foo 和 /index/bar , 不仅仅是 /index/ 。

同样的,如果我们去掉最前面的 ^ ( 'index/$' ), Django 一样会匹配由index/ 结束的任意 URL/index/ ,

比如 /foo/bar/index/ 。 因此,我们必须同时用上 ^ 和 $ 来精确匹配 URL/index/ 。不能多也不能少。

正则表达式

正则表达式 (或 regexes ) 是通用的文本模式匹配的方法。 Django URLconfs 允许你 使用任意的正则表达式来做强有力的 URL 映射,不过通常你实际上可能只需要使用很少的一部分功能。下面就是一些常用通用模式:

Django 是怎么处理请求的

我们必须对刚才所发生的几件事情进行一些说明。它们是运行 Django 开发服务器和构造 Web

页面请求的本质所在。

命令 python manage.py runserver 从同一目录载入文件 settings.py 。 该文件包含了这个特定的 Django 实例所有的各种可选配置,其中一个最重要的配置就是 ROOT_URLCONF 。

ROOT_URLCONF 告诉 Django 哪个 Python 模块应该用作本网站的 URLconf。还记得 django-admin.py startproject 创建的文件 settings.py 和 urls.py 吗? 这时系统自动生成的 settings.py 里 ROOT_URLCONF 默认设置是 urls.py 。

当访问 URL /time/ 时, Django 根据 ROOT_URLCONF 的设置装载 URLconf 。 然后按顺序逐个匹配 URLconf 里的 URLpatterns,直到找到一个匹配的。当找到这个匹配 的 URLpatterns就调用相关联的 view 函数,并把 HttpRequest 对象作为第一个参数。 (稍后再给出HttpRequest 的更多信息)

该view 函数负责返回一个 HttpResponse 对象。

你现在知道了怎么做一个 Django-powered 页面了,真的很简单,只需要写视图函数并用URLconfs 把它们和 URLs 对应起来。

你可能会认为用一系列正则表达式将 URLs 映射到函数也许会比较慢,但事实却会让你惊讶。

views 视图

接下来请求的处理就到了.../sign/views.py 中的 index 视图函数

#-*-coding:utf-8-*-

# Time:2017/11/13 17:08

# Author:YangYangJun

from django.http import HttpResponse

from django.shortcuts import render

def djangoStudy(request):

return HttpResponse('Hello DjangoStudy !')

def index(request):

return render(request,'index.html')

视图在我看来, 它在 Django 中非常重要, 是连接页面与数据的中间纽带。 拿登录的例子来讲, 用户在页面上输入了用户名和密码点击登录。 那么 request 请求会由视图来接收, 如何提取出用户名和密码的数据, 如

何用这些数据去查询数据库, 再如何将登录成功的页面返回给用户, 这些全部由视图层来完成。

Django 如何处理请求: 完整细节

除了刚才所说到的简明 URL-to-view 映射方式之外, Django 在请求处理方面提供了大量的灵活性

通过 URLconf 解析到哪个视图函数来返回 HttpResponse 可以通过中间件(middleware) 来短路或者增强。关于中间件的细节将在第十五章详细谈论,这里给出 下图 让你先了解 大体概念.。

当服务器收到一个 HTTP 请求以后,一个服务器特定的 handler 会创建 HttpRequest 并传递给下一个组件并处理。

这个 handler 然后调用所有可用的 Request 或者 View 中间件。这些类型的中间件通常是用来增强HttpRequest 对象来对一些特别类型的 request 做些特别处理。只要其中有一个返回 HttpResponse ,系统就跳过对视图的处理。

即便是最棒的程序员也会有出错的时候, 这个时候 异常处理中间件(exception middleware) 可以帮你的大忙。如果一个视图函数抛出异常,控制器会传递给异常处理中间件处理。如果这个 中间件没有返回HttpResponse ,意味着它不能处理这个异常,这个异常将会再次抛出。

即便是这样,你也不用担心。 Django 包含缺省的视图来生成友好的 404 和 500 回应(response)。

最后, response middleware 做发送 HttpResponse 给浏览器之前的后处理或者清除 请求用到的相关资源。

简单实例

新建一个html页面,命名为:index.html, urls和view配置如上图

templates 模板

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Django Page</title>

</head>

<body>

<h1>Hello Django</h1>

</body>

</html>

模板的载体就是我们所熟悉的 Web 页面了, Django 自带的有模板语言。 它的主要作用是如何展示数据,比如视图层返回的是一个字符串, 要如何显示在页面上; 返回的对象数组要如何显示等。 当然, 为了使页面更漂亮需要借助前端技术, 比如 CSS、 JavaScript 等。

运行后,结果如图

Django 简单的处理流程

以上是 Django如何将URL映射到视图 的全部内容, 来源链接: utcz.com/z/353821.html

回到顶部