首页 > 开发 > PHP > 正文

Symfony控制层深入详解

2024-05-04 22:31:47
字体:
来源:转载
供稿:网友

本文深入分析了Symfony控制层。分享给大家供大家参考,具体如下:

Symfony中控制层包含了连接业务逻辑与表现的代码,控制层为不同的使用分成了几个不同的部分。

1. 前端控制器是指向应用的唯一入口
2. 动作包含了应用的逻辑,他们检查请求的完整性并准备好表示层需要的数据
3. 请求、响应和Session对象提供访问请求参数、响应参数以及持久的用户数据,这些数据在控制层使用的很普遍
4. 过滤器是每个请求都要执行的代码的一部分,无论在动作前还是在动作后。可以自创过滤器。

前端控制器

所有WEB请求都将被前端控制器捕获,前端控制是给定环境下整个应用的唯一入口点。当前端控制接到一个请求,他使用路由系统匹配用户输入的URL的动作名和模块名。例如:

http://localhost/index.php/mymodule/myAction

URL调用了index.php脚本(也就是前端控制器),他被理解为:动作-myAction,模块-mymodule

前端控制器的工作细节

前端控制器分发请求,他仅执行那些通用的和共同的代码,包括:

1. 定义核心常量
2. 定位symfony库
3. 载入和初始化核心框架类
4. 载入配置信息
5. 解码请求URL,获取要执行的动作和请求参数
6. 如果动作不存在则专项404错误
7. 激活过滤器(比如,如果需要身份认证)
8. 执行过滤器,第一次
9. 执行动作,递交视图
10. 执行过滤器,第二次
11. 输出响应。

默认前端控制器

默认前端控制器叫作index.php,在项目的WEB/目录,他是一个简单的PHP文件,如下:

<?phpdefine('SF_ROOT_DIR',  realpath(dirname(__FILE__).'/..'));define('SF_APP',     'myapp');define('SF_ENVIRONMENT', 'prod');define('SF_DEBUG',    false);require_once(SF_ROOT_DIR.DIRECTORY_SEPARATOR.'apps'.DIRECTORY_SEPARATOR.SF_APP.DIRECTORY_SEPARATOR.'config'.DIRECTORY_SEPARATOR.'config.php');sfContext::getInstance()->getController()->dispatch();

这个文件在前面已经介绍过了:首先定义几个变量,然后引入应用的配置config.php,最后调用sfController(这是symfony MVC架构中的核心控制器对象)的dispatch()方法。最后一步将被过滤器链捕获。

调用另一个前端控制器来更换环境

每个环境存在一个前端控制器,环境定义在SF_ENVIRONMENT常量中。

创建新环境就和创建新的前端控制器一样简单,比如,你需要一个staging环境以使你的应用上线之前可以被客户测试。要创建staging环境,拷贝web/myapp_dev.php到web/myapp_staging.php,然后修改SF_ENVIRONMENT常量为staging。现在,你可以在所有的配置文件中增加staging段了设置新环境所需要的东西,看下面的示例:

## app.ymlstaging: mail:  webmaster:  dummy@mysite.com  contact:   dummy@mysite.comall: mail:  webmaster:  webmaster@mysite.com  contact:   contact@mysite.com##查看结果http://localhost/myapp_staging.php/mymodule/index            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表