• Django框架(九):视图(二) HttpRequest对象、HttpResponse对象


    1. HttpRequest对象

    服务器接收到http协议的请求后,会根据报文创建HttpRequest对象,这个对象不需要我们创建,直接使用服务器构造好的对象就可以。视图的第一个参数必须是HttpRequest对象,在django.http模块中定义了HttpRequest对象的API。

    1.1 属性 

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

    method:一个字符串,表示请求使用的HTTP方法,常用值包括:'GET'、'POST'。

    在浏览器中给出地址发出请求采用get方式,如超链接。

    在浏览器中点击表单的提交按钮发起请求,如果表单的method设置为post则为post请求。

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

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

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

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

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

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

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

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

    1.2 QueryDict对象 

    定义在django.http.QueryDict

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

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

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

    如果一个键同时拥有多个值将获取最后一个值

    如果键不存在则返回None值,可以设置默认值进行后续处理

    dict.get('',默认值)
    可简写为
    dict['']

    方法getlist():根据键获取值,值以列表返回,可以获取指定键的所有值

    如果键不存在则返回空列表[],可以设置默认值进行后续处理

    dict.getlist('',默认值)

    1.3 GET属性

    请求格式:在请求地址末尾使用?,之后以“键=值”的格式拆分,多个键值对之间以&连接。

    例:网址如下

    https://search.jd.com/Search?keyword=%E7%AC%94%E8%AE%B0%E6%9C%AC&enc=utf-8&wq=%E7%AC%94%E8%AE%B0%E6%9C%AC&pvid=e6ed133c7c1f4286b8579fed9c36e187

    其中的请求参数为:

    keyword=%E7%AC%94%E8%AE%B0%E6%9C%AC&enc=utf-8&wq=%E7%AC%94%E8%AE%B0%E6%9C%AC&pvid=e6ed133c7c1f4286b8579fed9c36e187

    分析请求参数,键为'a','b','c',转化为'10','20','python'。

    在Django中可以使用HttpRequest对象的GET属性获得get方方式请求的参数。

    GET属性是一个QueryDict类型的对象,键和值都是字符串类型。

    键是开发人员在编写代码时确定下来的。

    值是根据数据生成的。

    1.4 POST属性

    使用form表单请求时,方法方式为post继承发起post方式的请求,需要使用HttpRequest对象的POST属性接收参数,POST属性是一个QueryDict类型的对象。

    表单form如何提交参数呢?

    表单控件名称属性的值作为键,值属性的变量值,构成键值对提交。

    如果表单控件没有名称属性则不提交。

    对于复选框控件,名称属性的值相同为一组,被指定的项会被提交,出现一键多值的情况。

    键是表单控件名称属性的值,是由开发人员编写的。

    值是用户填写或选择的。

    2. HttpResponse对象

    视图在接收请求并处理后,必须返回HttpResponse对象或子对象。在django.http模块中定义了HttpResponse对象的API。HttpRequest对象由Django创建,HttpResponse对象由开发人员创建。

    2.1 属性

    content:表示返回的内容。

    charset:表示response采用的编码字符集,默认为utf-8。

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

    content-type:指定返回数据的的MIME类型,默认为'text/html'。

    2.2 方法

    _init_:创建HttpResponse对象后完成返回内容的初始化。

    set_cookie:设置Cookie信息。

    set_cookie(key, value='', max_age=None, expires=None)

    cookie是网站以键值对格式存储在浏览器中的一段纯文本信息,用于实现用户跟踪。

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

    expires是一个datetime或timedelta对象,会话将在这个指定的日期/时间过期。

    max_age与expires二选一。

    如果不指定过期时间,在关闭浏览器时cookie会过期。

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

    write:向响应体中写数据。

    2.3 子类JsonResponse

    在浏览器中使用javascript发起ajax请求时,返回json格式的数据,此处以jquery的get()方法为例。类JsonResponse继承自HttpResponse对象,被定义在django.http模块中,创建对象时接收字典作为参数。

    JsonResponse对象的content-type为'application/json'。

    2.4 子类HttpResponseRedirect

    当一个逻辑处理完成后,不需要向客户端呈现数据,而是转回到其它页面,如添加成功、修改成功、删除成功后显示数据列表,而数据的列表视图已经开发完成,此时不需要重新编写列表的代码,而是转到这个视图就可以,此时就需要模拟一个用户请求的效果,从一个视图转到另外一个视图,就称为重定向。

    Django中提供了HttpResponseRedirect对象实现重定向功能,这个类继承自HttpResponse,被定义在django.http模块中,返回的状态码为302。

    重定向简写函数redirect

    在django.shortcuts模块中为重定向类提供了简写函数redirect。

    修改booktest/views.py文件中red1视图,代码如下:

    from django.shortcuts import redirect
    ...
    def red1(request):
        return redirect('/')
  • 相关阅读:
    js 数据图表
    yii query builder
    mysql if
    这又是起点
    [cookie篇]从cookie-parser中间件说起
    How to find and fix Bash Shell-shock vulnerability CVE-2014-6271 in unix like system
    AngularJS打印问题
    笔记本上班时间自动静音下班自动打开
    SCP命令
    Installing Ruby 1.9.3 on Ubuntu 12.04 Precise Pengolin (without RVM)
  • 原文地址:https://www.cnblogs.com/liuhui0308/p/12228903.html
Copyright © 2020-2023  润新知