zoukankan      html  css  js  c++  java
  • Django

      

    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 交互式解释程序,输入 import
    sys ,接着输入 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 自带的有模板语言。 它的主要作用是如何展示数据,
    比如视图层返回的是一个字符串, 要如何显示在页面上; 返回的对象数组要如何显示等。 当然, 为了使页面
    更漂亮需要借助前端技术, 比如 CSSJavaScript 等。

    运行后,结果如图

     Django 简单的处理流程

  • 相关阅读:
    Java Tread多线程(2)多线程安全问题
    Android 自己定义ViewGroup 实战篇 -&gt; 实现FlowLayout
    类的继承私有成员问题
    HTTP协议之响应头Date与Age
    《长寿的基因》:尝试挑战主流医学界的观点,态度不严谨,有点像民间科学家。2星。
    《医疗产业大棋局》,4星。有点旧了,依旧是比较难得的有深度的中美两国医疗市场的概括与分析。
    《时间的朋友2016》:吴伯凡写的稿子,比去年李翔写的差。3星。
    《你凭什么做好互联网》。5星。洞察力比较强的从业者的经验集。适合互联网行业各级别各角色阅读。
    《长安十二时辰》。5星。大唐首都反恐24小时。基本是大片剧本。有创意的穿越架空小说。
    读过MBA的CEO更自私?《哈佛商业评论》2016年第12期。4星
  • 原文地址:https://www.cnblogs.com/BlueSkyyj/p/7839452.html
Copyright © 2011-2022 走看看