phalcon——调度控制器

时间:2021-05-30 11:38:09

将侦听者绑定到组件上:

use Phalcon\Mvc\Dispatcher as MvcDispatcher,

Phalcon\Events\Manager as EventsManager;

$di->set('dispatcher', function () {

// 创建一个事件管理

$eventsManager = new EventsManager();

// 为“dispatch”类型附上一个侦听者

$eventsManager->attach("dispatch", function ($event, $dispatcher) {

// ...

});

$dispatcher = new MvcDispatcher();

// 将$eventsManager绑定到视图组件

$dispatcher->setEventsManager($eventsManager);

return $dispatcher;

}, true);

一个实例化的控制器会自动作为事件调度的侦听者,所以你可以实现回调函数:

class PostsController extends \Phalcon\Mvc\Controller

{

public function beforeExecuteRoute($dispatcher)

{

// 在每一个找到的动作前执行

}

public function afterExecuteRoute($dispatcher)

{

// 在每一个找到的动作后执行

}

}

转发执行流到另一个控制器/动作:

$this->dispatcher->forward(array(

"controller" => "post",

"action" => "index"

));

$this->dispatcher->forward(array(

"action" => "search",

"params" => array(1, 2, 3)

));

(默认情况下,传递的参数会按URL传递的顺序传给对应的动作,你可以简单的调整你的应用来匹配你想要的URL格式)

获取参数:

获取全部参数:

$params = $this->dispatcher->getParams();  //获取到的是一个数组

获取指定参数:

$content = $this->dispatcher->getParam('content');  //获取到的是一个参数值

利用合适的调度循环事件,你还可以做:

URL调整   转换动作名

删除遗留的扩展名   注入模型实例

处理Not-Found错误

注意:

制造一个“forward”并不等同于制造一个HTTP的重定向。尽管这两者表面上最终效果都一样。 “forward”不会重新加载当前页面,全部的重定向都只发生在一个请求里面,而HTTP重定向则需要两次请求 才能完成这个流程。