插件根据此接口实现的所有方法都将在适当的时间自动被调用。
(Yaf >=1.0.0)
插件允许轻松扩展和定制框架。
插件是类。实际的类定义将根据组件而有所不同 - 你可能需要实现此接口,但事实仍然是插件本身就是一个类。
可以使用 Yaf_Dispatcher::registerPlugin() 将插件加载到 Yaf 中,注册后,插件根据此接口实现的所有方法都将在适当的时间被调用。
示例 #1 插件示例
<?php
/* bootstrap 类应该定义在 ./application/Bootstrap.php 下 */
class Bootstrap extends Yaf_Bootstrap_Abstract {
public function _initPlugin(Yaf_Dispatcher $dispatcher) {
/* 注册一个插件 */
$dispatcher->registerPlugin(new TestPlugin());
}
}
/* 插件类应该放在 ./application/plugins/ 下 */
class TestPlugin extends Yaf_Plugin_Abstract {
public function routerStartup(Yaf_Request_Abstract $request, Yaf_Response_Abstract $response) {
/* 路由器启动前
在此钩子中,用户可以进行一些 URL 重写 */
var_dump("routerStartup");
}
public function routerShutdown(Yaf_Request_Abstract $request, Yaf_Response_Abstract $response) {
/* 路由器完成
在此钩子中,用户可以进行登录检查 */
var_dump("routerShutdown");
}
public function dispatchLoopStartup(Yaf_Request_Abstract $request, Yaf_Response_Abstract $response) {
var_dump("dispatchLoopStartup");
}
public function preDispatch(Yaf_Request_Abstract $request, Yaf_Response_Abstract $response) {
var_dump("preDispatch");
}
public function postDispatch(Yaf_Request_Abstract $request, Yaf_Response_Abstract $response) {
var_dump("postDispatch");
}
public function dispatchLoopShutdown(Yaf_Request_Abstract $request, Yaf_Response_Abstract $response) {
/* 最终钩子
在此钩子中,用户可以进行日志记录或实现布局 */
var_dump("dispatchLoopShutdown");
}
}
Class IndexController extends Yaf_Controller_Abstract {
public function indexAction() {
return FALSE; // 阻止渲染
}
}
$config = array(
"application" => array(
"directory" => dirname(__FILE__) . "/application/",
),
);
$app = new Yaf_Application($config);
$app->bootstrap()->run();
?>
上面的示例将输出类似于以下内容
string(13) "routerStartup" string(14) "routerShutdown" string(19) "dispatchLoopStartup" string(11) "preDispatch" string(12) "postDispatch" string(20) "dispatchLoopShutdown"