Укоротить определения маршрута Zend Framework
Как я могу сократить определение моих пользовательских маршрутов в Zend Framework? В настоящее время у меня есть это определение:
$route = new Zend_Controller_Router_Route(
":module/:id",
array(
"controller" => "index",
"action" => "index"
),
array("id" => "\d+")
);
self::$frontController->getRouter()->addRoute('shortcutOne', $route);
$route = new Zend_Controller_Router_Route(
":module/:controller/:id",
array("action" => "index"),
array("id" => "\d+")
);
self::$frontController->getRouter()->addRoute('shortcutTwo', $route);
$route = new Zend_Controller_Router_Route(
":module/:controller/:action/:id",
null,
array("id" => "\d+")
);
self::$frontController->getRouter()->addRoute('shortcutThree', $route);
Есть ли способ лучше совместить эти правила?
И каковы ваши лучшие практики в том, где их разместить? В настоящее время я имею их в моем классе начальной загрузки сразу после инициализации Front Controller.
Ответы
Ответ 1
Когда дело доходит до настройки таких маршрутов, я использую конфигурационный файл. В качестве предпочтения я использую XML для хранения моих данных конфигурации, однако их можно так же легко сохранить в другом поддерживаемом формате. Затем я добавляю маршруты из конфига, в маршрутизатор в моем бутстрапе.
Config:
<config>
<routes>
<shortcutone type="Zend_Controller_Router_Route">
<route>:module/:id</route>
<defaults>
<controller>index</controller>
<action>index</action>
</defaults>
<reqs id="\d+">
</shortcutone>
<shortcuttwo type="Zend_Controller_Router_Route">
<route>:module/:controller/:id</route>
<defaults>
<controller>index</controller>
</defaults>
<reqs id="\d+">
</shortcuttwo>
<shortcutthree type="Zend_Controller_Router_Route">
<route>:module/:controller/:action/:id</route>
<defaults>
<controller>index</controller>
<action>index</action>
</defaults>
<reqs id="\d+">
</shortcutthree>
</routes>
</config>
Bootstrap
$config = new Zend_Config_Xml('config.xml');
$router = Zend_Controller_Front::getInstance()->getRouter();
$router->addConfig($config, 'routes');
Очевидно, есть и другие варианты, и я бы рекомендовал вам прочитать документацию, однако это подходит для вашего примера.
Ответ 2
Мой файл routes.ini начал получать действительно большой, поэтому я решил использовать Zend Caching для кэширования маршрутов после их анализа. Я использовал Xcache для решения кэширования бэкэнд. Вот код, который нужно поместить в файл Bootstrap.php:
protected function _initRoutes()
{
$backendType = 'Xcache';
$backendOptions = array();
// Instantiate a caching object for caching the routes
$cache = Zend_Cache::factory('File', $backendType,
array(
'automatic_serialization' => true,
'master_files'=>array(APPLICATION_PATH . '/configs/routes.ini')
),
$backendOptions
);
$frontController = Zend_Controller_Front::getInstance();
if(! $router = $cache->load('router')) {
// Load up .ini file and put the results in the cache
$routes = new Zend_Config_Ini (APPLICATION_PATH . '/configs/routes.ini', 'production');
$router = $frontController->getRouter();
$router->addConfig( $routes, 'routes' );
$cache->save($router, 'router');
}
else {
// Use cached version
$frontController->setRouter($router);
}
}
Ответ 3
Я предпочитаю использовать файлы *.ini поверх XML, особенно при использовании Zend, поскольку он более Zend-подобный и гораздо более легкий и компактный. Здесь почти аналогичная конфигурация с использованием Zend_Config_Ini()
.
application.ini
[routes]
routes.shortcutone.route=:module/:id
routes.shortcutone.defaults.controller=index
routes.shortcutone.defaults.action=index
routes.shortcutone.reqs=\d+
bootstrap.php
$config = new Zend_Config_Ini('application.ini', 'routes');
$router = Zend_Controller_Front::getInstance()->getRouter();
$router->addConfig($config, 'routes');
Обратите внимание, что раздел [routes]
в файле application.ini
можно переименовать. И когда он будет переименован, второй параметр Zend_Config_Ini()
должен отражать новый заголовок раздела.