Request源码浅析

本文介绍了WSGIRequest对象在处理HTTP请求时的作用,它是视图函数的第一个参数,包含了客户端的所有信息。重点讲解了Request对象的属性如path, method, GET, POST, FILES等,以及其只读特性。此外,还探讨了QueryDict对象,它是操作请求参数的字典类,提供了get和getlist等方法。" 134500525,11309352,SQL进阶:统计题目类型刷题数并升序排列,"['SQL', '数据库']
摘要由CSDN通过智能技术生成

WSGIRequest对象

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

#views.py
from django.http import HttpResponse
def index(request):
    # print(type(request))
    print(request.path)
    return HttpResponse('index')

打印结果

<class  django.core.handlers.wsgi.WSGIRequest>

进入WSGIRequest

class WSGIRequest(HttpRequest):
    def __init__(self, environ):
        script_name = get_script_name(environ)
        # If PATH_INFO is empty (e.g. accessing the SCRIPT_NAME URL without a
        # trailing slash), operate as if '/' was requested.
        path_info = get_path_info(environ) or '/'
        self.environ = environ
        self.path_info = path_info
        # be careful to only replace the first slash in the path because of
        # http://test/something and http://test//something being different as
        # stated in https://www.ietf.org/rfc/rfc2396.txt
        self.path = '%s/%s' % (script_name.rstrip(
@RequestBody注解用于将请求体中的数据绑定到方法的参数上。其源码实现主要涉及到RequestResponseBodyMethodProcessor类。该类实现了HandlerMethodArgumentResolver接口,具体负责处理方法参数的解析。 在RequestResponseBodyMethodProcessor类中,supportsParameter方法用于判断是否支持解析某个参数。它通过判断方法参数上是否存在@RequestBody注解来进行判断。如果存在该注解,则返回true,表示该参数可被解析为请求体数据。 resolveArgument方法则是具体进行参数解析的方法。它首先会获取请求的Content-Type,判断是否为application/json或application/xml等类型,以确保请求体的数据为JSON或XML格式。然后将请求体的数据转换为方法参数所需的对象。这里会使用HttpMessageConverter进行数据的转换,将请求体的数据转换为方法参数对应的对象。 综上所述,@RequestBody注解的源码实现主要通过RequestResponseBodyMethodProcessor类来实现,它负责判断是否支持解析参数以及将请求体数据转换为方法参数所需的对象。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* *2* [Spring 注解面面通 之 @RequestBody参数绑定源码解析](https://blog.csdn.net/securitit/article/details/110705815)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值