[Python] Django框架入门3——深入视图

说明:

  本文主要深入了解视图(views.py),涉及路由配置、定义视图、Request对象、Response对象、状态保持等。

 

一、路由配置

  1、配置位置(settings.py 的 ROOT_URLCONF)

    

    在settings.py中的ROOT_URLCONF指向的urls.py则是主要的路由配置文件。

 

  2、修改主路由文件(test2.urls)

1 from django.conf.urls import url, include
2 from django.contrib import admin
3 
4 urlpatterns = [
5     url(r'^admin/', admin.site.urls),
6     # 应用booktest的路由文件   
7     url(r'^booktest/', include('booktest.urls'))
8 ]

 

    urlpatterns是一个url()实例的列表,url(正则表达式, 视图函数, 名称name)

    编写URLconf注意点:

      如果需要从url中捕获一个值,需要在它周围设置一对圆括号,如:url(r'^pro/(\d+)$', views.pro, name='pro'),对应的请求url为[ http://127.0.0.1:8000/pro/112 ]这里的红色部分则为需要传到请求的参数。

      不需要添加前导的反斜杠,如应写为 “test/”而不是写作 “/test/”。

      每个正则表达式前面的r表示字符串的不转义。

    

    正则表达式非命名组,通过位置参数传递给视图

      url( r'^([0-9]+)/$', views.detail, name='detail' )

      这里的参数是按照正则匹配的顺序,对应视图的参数位置。对应的detail方法如:def detail(request, id)

    正则表达式命名组,通过关键字参数传递给视图,本例中关键字参数为id

      url( r'^(?P<id>[0-9]+)/$', views.detail, name='detail' )

      通过?P<参数名>与视图参数名一一对应。

    参数匹配规则:优先使用命名参数,如果没有命名参数则使用位置参数。

    每个捕获的参数都作为一个普通的python字符串传递给给视图。

 

  3、包含其他的URLconfs

    在应用中创建urls.py文件,定义本应用中的urlconf,再在项目的 urls.py中使用include:

 

     匹配过程:先与主URLconf匹配,成功后再用剩余的部分与应用的URLconf匹配,过程如下图:

 

    使用include可以去除URLconf的冗余,即已完成匹配的部分不会再下一次的匹配中使用。

    在include中通过namespace定义命名空间,用于反解析。

    

  4、URL的反解析

    如果在视图、模板中使用硬编码的链接,在urlconf发生改变的时候,维护起来不是那么容易。

    解决:在做链接的时,通过指向urlconf的名称,动态生成链接地址

    视图:使用django.core.urlresolvers.reverse()函数

    模板:使用url模板标签

 

二、定义视图(视图函数)

  def detail(request, id)

  视图本质是一个函数,视图的参数:一个HttpRequest实例,通过正则表达式获取的位置参数;通过正则表达式组获取的关键字参数。

  在应用目录下默认有views.py文件,一般视图都定义在这个文件中。

  如果处理功能过多,可以将函数定义到不同的py文件中(不推荐,推荐使用多应用,即新建应用)

 

 

三、Request对象

  服务器接收http协议的请求后,会根据报文创建HttpRequest对象。

  视图函数的第一参数是HttpRequest对象。

  在django.http模块中定义了HttpRequest对象的API。

  1、属性

    path:一个字符串,表示请求页面的完整路径,不包含域名。

    method:一个字符串,表示请求使用的HTTP请求方式,常用值有GET、POST。

    encoding:一个字符串,表示提交的数据的编码方式。

      如果是None则表示使用浏览器的默认设置,一般为utf-8

      这个属性是可写,可以通过修改它来修改访问表单数据使用的编码,接下来对属性的任何访问都使用新的encoding值。

    GET:一个类似于字典的对象(QueryDict对象),包含get请求方式的所有参数。

    POST:一个类似于字典的对象(QueryDict对象),包含post请求方式的所有参数。

    FILES:一个类似于字典的对象,包含所有的上传文件。

    COOKIE:一个标准的Python字典,包含所有的cookie,键值都为字符串。

    session:一个即可读又可写的类似于字典的对象,表示当前的会话,只当Django启用会话的支持时才可用,详见"状态保持"。

  

  2、方法

    is_ajax():如果请求是通过XMLHttpRequest发起的,则返回True。

 

  3、QueryDict对象

    定义在django.http.QueryDict。

    Request对象的属性GET、POST都是QueryDict类型的对象。

    与Python字典不同,QueryDict类型的对象用来处理同一个键带有多个值的情况。

    方法get():根据键获取值:

      只能获取键的一个值。

      如果一个件同时拥有多个值,获取最后一个值。

     

 

    方法getlist():根据键获取值:

      将键的值以列表返回,可以获取一个键的多个值

       

 

  4、GET属性

    request.GET['key']

    request.GET.get('key')

    request.GET.getlist('key')

  

  5、POST属性

    request.POST['key']

    request.POST.get('key')

    request.POST.getlist('key')

 

四、Response对象

  在django.http模块中定义了HttpResponse对象的API。

  HttpRequest对象由Django自动创建,HttpResponse对象由程序员创建。

  不调用模板,直接返回数据。

 

 

   调用模板

 

 

  

  1、Response的成员

    属性:

      context:表示返回的内容,字符串类型。

      charset:表示response采用的编码字符集,字符串类型。

      status_code:响应的HTTP响应的状态码。

      content-type:指定输出的MIME类型。

    方法:

      init:使用页内容实例化HttpResponse对象

      write(contetn):以文件的方式写。

      flush():以伟健的方式输出缓存区。

      set_cookie(key, value='', nax_age=None, expires=None):设置Cookie。

        key、value都是字符串类型;

        max_age是一个整数,表示在指定秒数后过期

        expires是一个datetime或timedelta对象,会话将在这个指定的日期/时间过期,注意datetime和timedelta值只有在使用PickleSerialize时才可序列化

        max_age与expires二选一

        如果不指定过期时间,则两个星期后过期。

      delete_cookie(key):删除指定的key的Cookie,如果key不存在什么也不发生。

 

  2、子类HttpResponseRedirect

    重定向、服务端跳转,构造函数的第一个参数用来指定重定向的地址:

  

     推荐使用反向解析

 

 

  3、子类JsonResponse

    返回json数据,一般用于异步请求。__init__(data),帮助用户创建JSOn编码的响应,参数data是字典对象。

    JsonResponse的默认content-Type为application/json。

  

   

  4、简写函数

    渲染视图 render

   

    重定向

     

 

五、状态保持

  1、启用session

    使用django-admin startproject myapp 创建的项目默认启用session

    开启只需修改settings.py文件

   

    禁用session:删除上面指定的两个值,禁用会话将节省一些性能消耗。

 

  2、使用session

    启用会话后,每个HttpRequest对象都将具有一个session属性,它是一个类字典的对象

    get('key', default=None):根据键获取会话的值。

    clear():清楚所有会话。

    flush():删除当前的会话数据并删除会话的Cookie。

    del request.session['member_id']:删除会话

 

posted @ 2018-08-23 12:50  蜗牛噢  阅读(847)  评论(0编辑  收藏  举报