控制器提供了一堆可以被调用的方法,即:action。action是控制器中用于处理请求的方法。默认情况下,全部 控制器public的方法都会映射到action并且可以通过URL访问。action负责解释请求和创建响应。 通常,响应是以渲染的视图格式被创建,但也存在其他的方式来创建(译者注:如AJAX请求返回JSON格式的数据)。
phalcon框架中,控制器必须要以Controller结尾,方法必须以Action结尾 一般控制器定义在app\Controllers 目录下, 当然自己也可以指定控制器加载目录
首先定义一个基类控制器,基类控制器继承自Phalcon\Mvc\Controller
。
这里定义一个IndexController继承自ControllerBase
在Action中没有默认值的参数为比传值,否则会出错。
在action中获取参数可以用下面几种方式
get传参
http://url.../控制器名/方法名/参数1/参数值1/参数名2/参数值2....
在控制器中,常常会因为用户非法访问或没有按照我们的逻辑代码执行,我们会抛出一个错误页面, 这里用到两个常用的方法,循环调度
$this->flash->error(".........");
$this->dispatcher->forward([
'controller' => 'Index',
'action' => 'err'
]);
Phalcon\Mvc\Controller 提供了初始化的函数,它会最先执行,并优于任何控制器 的其他action。不推荐使用“__construct”方法。
public function initialize()
{
}
Phalcon\Mvc\Controller 提供了一个实列化一个控制器之后立即执行的方法
publi function onConstruct()
{
}
// 控制器会自动作为 dispatcher 事件的侦听者,优先initialize方法执行
//前置钩子函数
public function beforeExecuteRoute()
{
}
//后置钩子函数
public function afterExecuteRoute()
{
}