Django框架视图介绍与使用详解

本文实例讲述了Django框架视图介绍与使用。分享给大家供大家参考,具体如下:

视图

  • 视图:即一个python函数,可以叫 视图函数,或者简称 视图,定义在 应用/views.py 文件中。
  • 作用:接收并处理请求,调用M和T,响应请求(返回HttpResponse或其子类)
  • 每一个用户请求,都对应着一个视图(和url地址),由视图处理请求后,再返回html页面内容给浏览器显示。

URL配置及匹配

作用:建立url地址和视图函数的对应关系,当用户请求某个url地址时,让django能找到对应的视图函数进行处理。

配置url:

在应用下创建urls.py,然后在项目下的urls.py文件中包含进来:

# 项目下的urls.py
urlpatterns = [
  ...
  # 包含应用下的urls.py文件
  url(正则表达式, include('应用名.urls'))
]

在应用下的urls.py中,进行url请求的配置:

# 应用下的urls.py
urlpatterns = [
  # 每一个url配置项都需要调用url函数,指定两个参数
  # 参数1: 匹配url的正则表达式
  # 参数2: 匹配成功后执行的视图函数
  url(正则表达式, 视图函数名),
]

案例:

通过http://127.0.0.1:8080/app01/index地址,要调用视图函数index访问首页。则可配置如下(域名和端口号不需要配置,只需要配置 app01/index 部分):

在app01应用中创建urls.py文件,在该文件中配置url和视图函数的对应关系:

# app01.py
urlpatterns = [
  ...
  # 进入首页
  url(r'^index$', views.index),
]

在项目下urls.py中,把应用下的urls.py包含进来:

# Project01/urls.py
urlpatterns = [
  # 包含应用app01下的urls.py
  url(r'^app01/', include('app01.urls')),
]

url匹配流程

输入如下地址,访问首页:

http://127.0.0.1:8000/app01/index?aa=1&bb=xx

匹配流程:

url配置规则 (针对应用下的url配置)

正则表达式 应使用 ^ 和 $ 严格匹配请求url的开头和结尾,以便匹配唯一的字符串

url匹配小结

  1. 域名、端口、参数不参与匹配
  2. 先到项目下的urls.py进行匹配,再到应用的urls.py匹配
  3. 自上而下的匹配
  4. 匹配成功的url部分会去掉,剩下的部分继续作匹配
  5. 匹配不成功提示404错误

视图函数

每一个请求的url地址,都对应着一个函数,叫视图函数,由视图函数处理请求后,再返回页面内容给浏览器显示。

应用/views.py 下,定义视图函数,示例:

from django.http import HttpResponse
# 必须有一个参数request
def index(request):
  """进入首页的视图函数"""
  # 处理完请求,返回字符串内容给浏览器显示
  return HttpResponse("Hello Python")

捕获URL中的值

问题:对于如下的url地址,如何捕获url上的两个值(代表新闻类别和页码),并传给视图函数处理?

输入如下地址:

# /show_news/新闻类别/页码
http://127.0.0.1:8000/show_news/1/2

解决: 把url中的需要获取的值部分,设置为正则表达式的一个组。 django在进行url匹配时,就会自动把匹配成功的内容,作为参数传递给视图函数。

位置参数: url中的正则表达式组,和视图函数中的参数一一对应,函数中的参数名可以随意指定。

示例:

# 位置参数:新闻查看/新闻类别/第几页
url(r'^show_news/(\d+)/(\d+)$', views.show_news),
# 视图函数:views.py
def show_news(request, a, b):
  """显示新闻界面"""
  return HttpResponse("新闻界面:%s %s" % (a, b))

关键字参数: 在位置参数的基础上,对正则表达式分组进行命名:

?P<组名>

视图函数中参数名,必须和正则表达式分组名一致。

示例:

# 关键字参数:新闻查看/新闻类别/第几页
url(r'^show_news2/(?P<category>\d+)/(?P<page_no>\d+)$', views.show_news2),
# 视图函数:views.py
def show_news2(request, category, page_no):
  """显示新闻界面2"""
  return HttpResponse("新闻界面:%s %s" % (category, page_no))

错误视图

Django内置了处理HTTP错误的视图(在django.views.defaults包下),主要错误及视图包括:

  • 404错误:page_not_found 视图 (找不到界面)
  • 500错误:server_error 视图    (服务器内部错误)
  • 403错误:permission_denied 视图    (权限拒绝)

一、404错误及视图

url匹配失败后,django会调用内置的 page_not_found 视图函数,该视图函数会调用 404.html的模板进行显示。

开发阶段可以开启调试模式,但产品上线后,要关闭调试模式。关闭调试模式后,会显示一个标准的错误页面

# 关闭调试模式(开发模式)
DEBUG = False
# 表示允许哪些域名可访问当前网站
ALLOWED_HOSTS = ['*']

404错误界面可以自定义: 在项目templates目录面创建404.html,django找不到界面时,就会使用该界面了

二、500错误及视图

若是在执行视图函数时出现运行时错误,Django会默认会调用 django.views.defaults.server_error 视图,加载并显示 500.html 模板:

server error (500)

类似的,可以在项目的templates目录下,创建500.html来自定义该界面。

三、Django出错日志查看:

查看 Exception Type 以及 Exception Value

查看 Traceback中的出错行

希望本文所述对大家基于Django框架的Python程序设计有所帮助。

(0)

相关推荐

  • Django中URL视图函数的一些高级概念介绍

    说到关于请求方法的分支,让我们来看一下可以用什么好的方法来实现它. 考虑这个 URLconf/view 设计: # urls.py from django.conf.urls.defaults import * from mysite import views urlpatterns = patterns('', # ... (r'^somepage/$', views.some_page), # ... ) # views.py from django.http import Http404,

  • Django框架下在视图中使用模版的方法

    打开current_datetime 视图. 以下是其内容: from django.http import HttpResponse import datetime def current_datetime(request): now = datetime.datetime.now() html = "<html><body>It is now %s.</body></html>" % now return HttpResponse(h

  • Django视图和URL配置详解

    本文研究的主要是Django视图和URL配置,具体介绍如下. 一.视图 1.在mysite文件夹下,创建views.py文件(文件名没有特别的要求): from django.http import HttpResponse def hello(request): return HttpResponse("Hello world") 2.修改mysite文件夹下的urls.py文件: from django.conf.urls import url from django.contri

  • 详解Python的Django框架中的通用视图

    通用视图 1. 前言 回想一下,在Django中view层起到的作用是相当于controller的角色,在view中实施的 动作,一般是取得请求参数,再从model中得到数据,再通过数据创建模板,返回相应 响应对象.但在一些比较通用的功能中,比如显示对象列表,显示某对象信息,如果反复 写这么多流程的代码,也是一件浪费时间的事,在这里,Django同样给我们提供了类似的 "shortcut"捷径--通用视图. 2. 使用通用视图 使用通用视图的方法就是在urls.py这个路径配置文件中进

  • Django的URLconf中使用缺省视图参数的方法

    一个方便的特性是你可以给一个视图指定默认的参数. 这样,当没有给这个参数赋值的时候将会使用默认的值. 例子: # urls.py from django.conf.urls.defaults import * from mysite import views urlpatterns = patterns('', (r'^blog/$', views.page), (r'^blog/page(?P<num>\d+)/$', views.page), ) # views.py def page(r

  • 详解Django通用视图中的函数包装

    用函数包装来处理复杂的数据过滤 另一个常见的需求是按URL里的关键字来过滤数据对象. 之前,我们在URLconf中硬编码了出版商的名字,但是如果我们想用一个视图就显示某个任意指定的出版商的所有书籍,那该怎么办呢? 我们可以通过对 object_list 通用视图进行包装来避免 写一大堆的手工代码. 按惯例,我们先从写URL配置开始: urlpatterns = patterns('', (r'^publishers/$', list_detail.object_list, publisher_i

  • 在Django中创建第一个静态视图

    正如我们的第一个目标,创建一个网页,用来输出这个著名的示例信息: Hello world. 如果你曾经发布过Hello world页面,但是没有使用网页框架,只是简单的在hello.html文本文件中输入Hello World,然后上传到任意的一个网页服务器上. 注意,在这个过程中,你已经说明了两个关于这个网页的关键信息: 它包括(字符串 "Hello world")和它的URL( http://www.example.com/hello.html , 如果你把文件放在子目录,也可能是

  • 详解Django框架中的视图级缓存

    更加颗粒级的缓存框架使用方法是对单个视图的输出进行缓存. django.views.decorators.cache定义了一个自动缓存视图响应的cache_page装饰器. 他是很容易使用的: from django.views.decorators.cache import cache_page def my_view(request): # ... my_view = cache_page(my_view, 60 * 15) 也可以使用Python2.4的装饰器语法: @cache_page

  • 在Django的视图中使用数据库查询的方法

    在视图中也有笨方法可以从数据库中获取数据. 很简单: 用现有的任何 Python 类库执行一条 SQL 查询并对结果进行一些处理. 在本例的视图中,我们使用了 MySQLdb 类库(可以从 http://www.djangoproject.com/r/python-mysql/ 获得)来连接 MySQL 数据库,取回一些记录,将它们提供给模板以显示一个网页: from django.shortcuts import render_to_response import MySQLdb def bo

  • 在Django中创建动态视图的教程

    在我们的`` current_datetime`` 视图范例中,尽管内容是动态的,但是URL ( /time/ )是静态的. 在 大多数动态web应用程序,URL通常都包含有相关的参数. 举个例子,一家在线书店会为每一本书提供一个URL,如:/books/243/./books/81196/. 让我们创建第三个视图来显示当前时间和加上时间偏差量的时间,设计是这样的: /time/plus/1/ 显示当前时间+1个小时的页面 /time/plus/2/ 显示当前时间+2个小时的页面 /time/p

  • 在Python的Django框架中使用通用视图的方法

    使用通用视图的方法是在URLconf文件中创建配置字典,然后把这些字典作为URLconf元组的第三个成员. 例如,下面是一个呈现静态"关于"页面的URLconf: from django.conf.urls.defaults import * from django.views.generic.simple import direct_to_template urlpatterns = patterns('', (r'^about/$', direct_to_template, { '

随机推荐