django的url路由系统处理http请求过程的源码解析

浏览器发起请求

django的服务端口监听到请求

调用url匹配请求内容

url(r'^index/$', index.as_view(), name='index'),

根据匹配的请求内容

url(r'^index/$', index.as_view(), name='index'),

调用类方法:并调用类方法as_view

 
 

 然后实例化view类,并继承listview类,复写相关变量的值

 

 解析request方法,为get,再调用BaseListView 的get方法,在get方法中调用get_context_data(),获取之前内部赋值和自定义赋值的变量后,组成的context数据,最后将获取的数据渲染到定义的模板上

PS:通过pycharm的debug进行代码跟踪,获取复写函数get_context_data()的内部源码调用逻辑

通过debug对复写函数get_context_data()的这几行代码打断点,然后点击debug启动,看到成功启动后打打印

然后通过页面发起请求http://127.0.0.1:8000/index/,再在ide中查看debug模式下代码调用流程

通过图中1,继续执行下一个断点的代码

通过图中2,查看代码调用关系:

通过图中3,断点代码相关变量的值

猜你喜欢

转载自blog.csdn.net/weixin_35264169/article/details/81139934