Symfony学习--HttpKernel组件

简介:

http://symfony.com/doc/2.1/components/http_kernel/introduction.html

HttpKernel这个类提供的功能说白了就是将Request转换成Response。它使用一个流程的工作流似的方式。

整个流程图大致如下:

Image

HttpKernel最核心的是handle(); 它的工作就是将上图的Request转换成Response。

handle()是由事件驱动的,你可以建立一系列的事件监听

典型的代码如下:

Image(1)

步骤:

1 处理request

一个request可以有多个listener,listener可能直接中断,并且直接返回Response。

2 解析controller

这里有个ControllerResolver类来对controller进行解析,它有两个接口:

getController

getArguments

如果你要自定义这个解析类,你就需要自己实现这两个接口。

3 处理controller

初始化,并且在实际执行前改变对应的控制器

4 获取controller参数

通过getArguments()这个方法来获取controller的参数

5 实际调用controller

这个阶段会实际调用controller了,并得到返回的数据

6 view

这个阶段就是mvc的view层。将controller中返回的数据加上view层

7 kernel.response 事件

在数据返回前改变对应的Response事件。

8 kernel.terminate事件

在数据返回给用户前处理一些较重的事件。

异常处理:


是触发了kernel.exception事件

每个异常都返回了一个GetResponseForExceptionEvent事件,你可以使用getException()方法获取原始的异常。

目录
相关文章
|
7月前
|
JavaScript 前端开发
vue3瀑布流布局(使用 Vue 3 框架的单文件组件格式(Single-File Component)编写的)
vue3瀑布流布局(使用 Vue 3 框架的单文件组件格式(Single-File Component)编写的)
194 0
|
8月前
|
前端开发
React 安装使用 Less(详细流程,包含 webpack、craco 方式)
React 安装使用 Less(详细流程,包含 webpack、craco 方式)
156 0
|
缓存 JSON 前端开发
【Vue五分钟】五分钟了解webpack的高级概念
其实如果配置了 useBuiltIns 就不会需要再 import babel profill。 实际上目前的话虽然只是引入了某个模块的某个方法,在打 包还是会把模块的所有方法引入,最好是引入什么打包什么, 这就需要 tree shaking,摇掉不需要的内容。
【Vue五分钟】五分钟了解webpack的高级概念
|
前端开发
第十五章 webpack5项目搭建React-Cli(配置合并)
介绍将开发模式和生产模式合并为一个配置文件的步骤
122 0
|
缓存 JavaScript
第二十章 webpack5项目搭建Vue-Cli(配置优化)
本章介绍vue框架搭配组件库的一些优化配置
237 0
|
前端开发
第十九章 webpack5项目搭建Vue-Cli(合并配置)
本章是介绍如何将vue-cli的开模式和生产模式合并的步骤
139 0
|
JavaScript 前端开发
第十七章 webpack5项目搭建Vue-Cli(开发模式)
本章介绍配置Vue-cli开发模式的步骤
211 0
第十七章 webpack5项目搭建Vue-Cli(开发模式)
|
开发者
第十六章 webpack5项目搭建React-Cli(配置优化)
本章介绍开发者如何根据项目来优化配置文件
|
JavaScript
Ant Design Vue 框架的a-table嵌套a-form-model达到验证效果
Ant Design Vue 框架的a-table嵌套a-form-model达到验证效果
1013 0
|
前端开发
symfony2框架配置页面
symfony2框架配置页面
102 0
symfony2框架配置页面