Django请求和响应设置

2019-02-12  本文已影响0人  LittleTrue

前置文章已经完成了项目框架结构和应用程序的设置: Django安装、运行与python虚拟环境配置


编写第一个视图

基于已经将项目和应用运行起来的虚拟环境, 开始创建第一个视图以供访问
直接编辑应用程序下的views.py

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

def index(request):
    return HttpResponse("HelloWorld")

传统网页页面包括两件事: 内容设计和url寻址。使用Django,你会用不同的方法来说明这两件事 页面的内容是靠view function(视图函数) 来产生

首先,我们从 django.http 模块导入(import )我们需要导入这些类,因为我们会在后面用到。
--
接下来,我们定义一个叫做hello 的视图函数。
每个视图函数至少要有一个参数,通常被叫作request。 这是一个触发这个视图、包含当前Web请求信息的对象,是类django.http.HttpRequest的一个实例。在这个示例中,我们虽然不用request做任何事情,然而它仍必须是这个视图的第一个参数。

路由设置

我们需要将一个 URL 映射到上面的视图——这就是我们需要 URLconf 的原因了。
为了创建 URLconf,请在 应用 目录里新建一个 urls.py 文件。你的应用目录现在看起来应该是这样:

编辑容器内的urls文件。
from django.urls import path
from . import views

urlpatterns = [
    path('index', views.index, name='index'),
]
编辑项目根目录的urls文件。
from django.contrib import admin
from django.urls import include, path

urlpatterns = [
    path('GDweb/', include('GDweb.urls')),
    path('admin/', admin.site.urls),
]

下一步是要在项目根目录 URLconf 文件中指定我们创建的容器内 urls 模块。

函数 include()
include允许引用其它 URLconfs。每当 Django 遇到 :func:<cite>~django.urls.include</cite> 时,它会截断与此项匹配的 URL 的部分,并将剩余的字符串发送到 URLconf 以供进一步处理。

何时使用 include()
当要引入其它位置的 URL 模式文件时你应该总是使用 include()admin.site.urls 是唯一例外。

配置好后,即可使用http://127.0.0.1:8000/GDweb/index访问模块方法了。


路由模式

函数 path() 具有四个参数,两个必须参数:routeview,两个可选参数:kwargsname。现在,是时候来研究这些参数的含义了。

path() 参数: route

route 是一个匹配 URL 的准则(类似正则表达式)。当 Django 响应一个请求时,它会从 urlpatterns 的第一项开始,按顺序依次匹配列表中的项,直到找到匹配的项。

这些准则不会匹配 GET 和 POST 参数或域名。例如,URLconf 在处理请求 https://www.example.com/myapp/ 时,它会尝试匹配 myapp/ 。处理请求 https://www.example.com/myapp/?page=3 时,也只会尝试匹配 myapp/

Django URLconfs 允许你在这一参数 使用任意的正则表达式来做强有力的URL映射,不过通常你实际上可能只需要使用很少的一 部分功能。

比较常用的是django自己定义的遵循restfull设计的带参路由格式:

from django.urls import path
from . import views

urlpatterns = [
    # ex: /polls/
    path('', views.index, name='index'),
    # ex: /polls/5/
    path('<int:question_id>/', views.detail, name='detail'),
    # ex: /polls/5/results/
    path('<int:question_id>/results/', views.results, name='results'),
    # ex: /polls/5/vote/
    path('<int:question_id>/vote/', views.vote, name='vote'),
]

以上注册带参路由, 然后在视图方法中注册参数:
(以下仅为在视图中输出全模版的用法)

from django.http import HttpResponse
def index(request):
    return HttpResponse("HelloWorld")

def detail(request, question_id):
    return HttpResponse("show something:" + str(question_id))

path() 参数: view

当 Django 找到了一个匹配的准则,就会调用这个特定的视图函数,并传入一个 HttpRequest 对象作为第一个参数,被“捕获”的参数以关键字参数的形式传入。稍后,我们会给出一个例子。

path() 参数: kwargs

任意个关键字参数可以作为一个字典传递给目标视图函数。本教程中不会使用这一特性。

path() 参数: name

为你的 URL 取名能使你在 Django 的任意地方唯一地引用它,尤其是在模板中。这个有用的特性允许你只改一个文件就能全局地修改某个 URL 模式。

上一篇 下一篇

猜你喜欢

热点阅读