Django WSGIRequest对象

1. WSGIRequest对象作用

Django在接收到http请求之后,会根据http请求携带的参数以及报文信息创建一个WSGIRequest对象,并且作为视图函数第一个参数传给视图函数。也就是我们经常看到的request参数。在这个对象上我们可以找到客户端上传上来的所有信息。这个对象的完整路径是django.core.handlers.wsgi.WSGIRequest。

def index(request):
    print(type(request))
    pass

#打印结果:<class ‘django.core.handlers.wsgi.WSGIRequest‘>

2. WSGIRequest对象封装了什么?

我们可以打开一个网页,例如京东。我们F12,打开检查,看右边的内容,就是我们浏览器请求服务器会传输的一些信息了。这些信息在django中都会被django的WSGIRequest对象存储。

3. WSGIRequest有哪些属性?其实我们大概就可以猜到了

WSGIRequest对象上大部分的属性都是只读的。因为这些属性是从客户端上传上来的,没必要做任何的修改。
以下将对一些常用的属性进行讲解:
path:请求服务器的完整“路径”,但不包含域名和参数。比如http://www.jd.com/aaa/bbb/,那么path就是/aa/bbb/;
get_full_path():返回完整的path。如果有查询字符串,还会加上查询字符串。比如/aaa/?username=huang
get_raw_uri():获取请求的完整url,如http://www.jd.com//aaa/?username=huang
method:当前请求的http方法。比如是GET,POST,HEAD,PUT等;
GET:一个django.http.request.QueryDict对象。操作起来类似于字典。这个属性中包含了所有以?xxx=xxx的方式上传上来的参数;
POST:也是一个django.http.request.QueryDict对象。这个属性中包含了所有以POST方式上传上来的参数;
FILES:也是一个django.http.request.QueryDict对象。这个属性中包含了所有上传的文件;
COOKIES:一个标准的Python字典,包含所有的cookie,键值对都是字符串类型;
session:一个类似于字典的对象。用来操作服务器的session;
is_secure():是否是采用https协议
is_ajax():是否采用ajax发送的请求。原理就是判断请求头中是否存在X-Requested-With:XMLHttpRequest;
get_host():服务器的域名。如果在访问的时候还有端口号,那么会加上端口号。比如www.baidu.com:9000;
META:存储的客户端发送上来的所有header信息;
        CONTENT_LENGTH:请求的正文的长度(是一个字符串);
        CONTENT_TYPE:请求的正文的MIME类型;
        HTTP_ACCEPT:响应可接收的Content-Type;
        HTTP_ACCEPT_ENCODING:响应可接收的编码;
        HTTP_ACCEPT_LANGUAGE: 响应可接收的语言;
        HTTP_HOST:客户端发送的HOST值;
        HTTP_REFERER:在访问这个页面上一个页面的url;
        QUERY_STRING:单个字符串形式的查询字符串(未解析过的形式);
        REMOTE_ADDR:客户端的IP地址。如果服务器使用了nginx做反向代理或者负载均衡,那么这个值返回的
                               是127.0.0.1(nginx服务器本身),这时候可以使用HTTP_X_FORWARDED_FOR来获取,
        SERVER_NAME:服务器域名;
        SERVER_PORT:服务器端口号,是一个字符串类型;

4. 案例

def index(request):
    # 首页返回所有文章
    print(type(request))
    print(request.GET)
    print(request.POST)
    print(request.FILES)
    print(request.COOKIES)
    print(request.session)
    print(request.META)
    #print(request.META["HTTP_HOST"])
    #print(request.META["HTTP_REFERER"])
    #print(request.META["REMOTE_ADDR"])
    #print(request.META["HTTP_X_FORWARDED_FOR"])
    #print(request.META["SERVER_PORT"])
    #return HttpResponse("成功")

#打印结果如下,因为没有GET参数和POST参数,所以下面的QueryDict都是空

5. QueryDict对象案例

我们平时用的request.GET和request.POST从上面结果可以看到都是QueryDict对象, 它们还有一个get和getlist方法,我们看看有什么差异。



(1)先看看get方法

def add_article(request):
    if request.method == "GET":
        return render(request, ‘k01_method_demo/add_article.html‘)
    else:
        title = request.POST.get("title")
        content = request.POST.get("content")
        price = request.POST.get("price")
        tags = request.POST.get("tags")
        print(title, content, price)
        print(tags)
        return HttpResponse("成功")

前端代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Add article</title>
</head>
<body>
<form action="{% url ‘k01_method_demo:add_article‘ %}" method="post">
    <table>
        <tbody>
            <tr>
                <td>标题:</td>
                <td><input type="text" name="title"></td>
            </tr>
            <tr>
                <td>内容:</td>
                <td><input type="content" name="content"></td>
            </tr>
            <tr>
                <td>价格:</td>
                <td><input type="price" name="price"></td>
            </tr>
            <tr>
                <td>标签:</td>
                <td>
                    <label>
                        <input type="checkbox" name="tags" value="历史">历史
                    </label>
                    <label>
                        <input type="checkbox" name="tags" value="文学">文学
                    </label>
                    <label>
                        <input type="checkbox" name="tags" value="古装">古装
                    </label>
                    <label>
                        <input type="checkbox" name="tags" value="武侠">武侠
                    </label>
                    <label>
                        <input type="checkbox" name="tags" value="武侠">都市
                    </label>
                </td>
            </tr>
            <tr>
                <td></td>
                <td><input type="submit" value="提交"></td>
            </tr>
        </tbody>
    </table>
</form>
</body>
</html>

步骤1: 操作提交,我们这里标签选择了两个

步骤2: 打印结果

可以看到只是打印了古装,历史却没有打印出来



(2)先看看getlist方法

def add_article(request):
    if request.method == "GET":
        return render(request, ‘k01_method_demo/add_article.html‘)
    else:
        title = request.POST.get("title")
        content = request.POST.get("content")
        price = request.POST.get("price")
        tags = request.POST.getlist("tags") #这里换成了getlist方法
        print(title, content, price)
        print(tags)
        return HttpResponse("成功")

#使用getlist,我们可以发现多选按钮被打印出来了。

原文地址:https://blog.51cto.com/jiajinh/2434413

时间: 2024-11-25 00:18:38

Django WSGIRequest对象的相关文章

Django F对象的使用

概念 class FF()是代表模型字段的值,也就是说对于一些特殊的字段的操作,我们不需要用Python把数据先取到内存中,然后操作,在存储到db中了. 场景 例1:我们有个统计点击量的字段,每次更新的操作其实就是把字段的值加1. 一般我们的做法是把这条记录取出来,把相应字段加+1,然后在save,类似下面的代码: # Tintin filed a news story! reporter = Reporters.objects.get(name='Tintin') reporter.stori

【转载】使用信号监控 Django 模型对象字段值的变化

转载出处:http://blog.csdn.net/pushiqiang/article/details/74949465 Django 信号 (Signals) 的功能类似于 WordPress 的动作 (action),用于为项目全局增加事件的广播 (dispatch) 与接收 (receive) 机制.其中,灵活使用其内置的模型信号 (Model Signals) 的接收功能就可以监控大部分模型对象 (Model instances) 的变化.因为不需要修改模型本身的代码,在进行跨应用 (

Django HttpRequest对象的一些属性与方法

HttpRequest对象的属性 属性 描述 path 表示提交请求页面完整地址的字符串,不包括域名,如 "/music/bands/the_beatles/". method 表示提交请求使用的HTTP方法.它总是大写的.例如: if request.method == 'GET': do_something() elif request.method == 'POST': do_something_else() GET 一个类字典对象,包含所有的HTTP的GET参数的信息.见 Qu

django HttpRequest对象

每当一个用户请求发送过来,Django将HTTP数据包中的相关内容,打包成为一个HttpRequest对象,并传递给每个视图函数作为第一位置参数,也就是request,供我们调用. HttpRequest对象中包含了非常多的重要的信息和数据,应该熟练掌握它. 类定义:class HttpRequest[source] 一.属性 HttpRequest对象的大部分属性是只读的,除非特别注明. 1. HttpRequest.scheme 字符串类型,表示请求的协议种类,'http'或'https'.

django HttpResponse对象

HttpResponse对象 概述: 作用:给浏览器返回数据 HttpRequest对象是由Django创建的,HttpResponse对象是由程序员创建 用法: 不用模板,直接返回数据 语句示例:return HttpResponse("Sunck is a good man") 调用模板 使用render方法 原型:render(request, templateName[, context]) 作用:结合数据和模板,返回一个完整的HTML页面 参数: request:请求体对象

Python - Django - request 对象

request.method: 获取请求的方法,例如 GET.POST 等 views.py: from django.shortcuts import render, HttpResponse # request 对象 def test(request): print(request.method) return render(request, "test.html") 访问页面 可以通过 request.method 查看请求方式 request.GET: 用来获取 URL 里面的

django关系对象映射(Object Relational Mapping,简称ORM)

Model 创建数据库,设计表结构和字段 django中遵循 Code Frist 的原则,即:根据代码中定义的类来自动生成数据库表 from django.db import models class userinfo(models.Model): name = models.CharField(max_length=30) email = models.EmailField() memo = models.TextField() 连表结构 一对多:models.ForeignKey(其他表)

django的HTTPREQUEST对象

Django使用request和response对象 当请求一张页面时,Django把请求的metadata数据包装成一个HttpRequest对象,然后Django加载合适的view方法,把这个HttpRequest 对象作为第一个参数传给view方法.任何view方法都应该返回一个HttpResponse对象. 我们在本书中大量使用这两个对象:本附录详细解释HttpRequest和HttpResponse对象. HttpRequest HttpRequest代表一个来自uesr-agent的

21:序列化django对象

django的序列化框架提供了一个把django对象转换成其他格式的机制,通常这些其他的格式都是基于文本的并且用于通过一个管道发送django对象,但一个序列器是可能处理任何一个格式的(基于文本或者不是) django的序列化类位于django.core下面的serializers文件夹里面,base.py文件里面定义了序列器和反序列器的基类以及一些异常,__init__.py文件定义了如何根据格式来选择对应的序列器等内容,我们一起来看看吧 __init__.py和base.py文件的函数原型如