Django的请求响应完整流程解析
图例:
Django:Django内部自己实现的代码。
Your code: 程序员实现的代码。
Extendable:可对工作进行全局扩展的,各种中间件。
External:外部工具,例如浏览器、数据库。
步骤详细解释:
1、通过Http客户端(浏览器或爬虫)发起请求,访问到modwsgi,modwsgi使用Django的WSGI模块实现(通过manage.py runserver启动)。启动WSGI模块后会给每一个用户生成一个Handler句柄(WSGIHandler类控制整个请求到响应的流程),自动从HttpRequest类实例化Request对象。(实际工作中Django生产环境部署需要接收Http的请求,再转到WSGI请求上)
2、经过请求中间件,对整个请求做全局预处理。
例如:1>反爬虫,有没有cookie或者特殊的Http头的一些校验,如果有就放行;如果没有,不需要再经过后续流程,直接返回到返回中间件404或者418,给modwsgi再传到浏览器。
2>防止跨站攻击,存放全站保护机制CSRF配置,对未授权的请求进行处理。
3、URLConf对url进行解析,根据编写的urls.py方式来接受用户的请求并向后继续访问。
4、请求视图之前,View中间件对对Request做处理,如果有问题直接返回给返回中间件,再到modwsgi最终传到浏览器。(例如:请求页面不存在,如果DEBUG=True可以看到Django调试页面;如果未开调试返回404)
5、调用自己编写的View视图函数,进来的是HttpRequest,返回的是HttpResponse。
6、调用自己编写的Model视图函数。
7、通过模型的查询管理器访问数据库,例如:object。
8、上下文,进一步使View和Model进行解耦,或者判断当前运行的状态。
9、没有调用相应Model,直接通过render返回模板,通过自己编写的模板再经过view进行返回。
注:Django中当产生一个新请求时,modwsgi通过HttpRequest类产生Request实例,且每次请求都携带请求对象。
字母表示的内容均为扩展:
a、b:使用Template时渲染只包含HTML的网页,也可使用models.py携带从数据库中取出的对象,绑定到Template模板里,通过Filters和Tags将变量替换进去进行渲染输出。
c:正确结果:返回HttpResponse对象;出现错误:返回抛出的异常,返回错误信息打印。
d、e:将经过返回中间件统一处理过的Response返回给WSGI模块,再返回到浏览器。
相关问题:
使用Django开发RESTful API接口,Get请求正常,POST上传文件时为什么抓取不到?
答:Django会将上传文件数据放到_files属性当中,且只有当Content-Type是multipart/form-data时,才会有数据。