(Yaf >=1.0.0)
Yaf_Route_Rewrite::__construct — Конструктор класса Yaf_Route_Rewrite
match
Шаблон, который будет использоваться для сопоставления URI запроса, если
он не совпадает, Yaf_Route_Rewrite вернёт
false
.
Вы можете использовать: стиль имени для именования совпадающих сегментов и использовать * для соответствия остальным сегментам URL.
route
Когда шаблон совпадения соответствует запросу uri, Yaf_Route_Rewrite будет использовать это, чтобы решить, какой модуль/контроллер/действие является пунктом назначения.
Любой модуль/контроллер/действие в этом массиве не является обязательным, если вы не назначите конкретное значение, оно будет перенаправлено на значение по умолчанию.
verify
Пример #1 Пример использования класса Yaf_Route_Rewrite
<?php
/**
* Добавить маршрут перезаписи в стек маршрутов Yaf_Router
*/
Yaf_Dispatcher::getInstance()->getRouter()->addRoute("name",
new Yaf_Route_rewrite(
"/product/:name/:id/*", //запрос на совпадение с ведущим "/product"
array(
'controller' => "product", //маршрут к контроллеру product,
),
)
);
?>
Вывод приведённого примера будет похож на:
/* для http://yourdomain.com/product/foo/22/foo/bar * результатом маршрута будут следующие значения: */ array( "controller" => "product", "module" => "index", //(по умолчанию) "action" => "index", //(по умолчанию) ) /** * и параметры запроса: */ array( "name" => "foo", "id" => 22, "foo" => bar )
Пример #2 Пример использования класса Yaf_Route_Rewrite
<?php
/**
* Добавьте маршрут перезаписи в стек маршрутов Yaf_Router, вызвав addconfig
*/
$config = array(
"name" => array(
"type" => "rewrite", //маршрут Yaf_Route_Rewrite
"match" => "/user-list/:id", //совпадение только по /user/list/?/
"route" => array(
'controller' => "user", //маршрут к контроллеру user,
'action' => "list", //маршрут к действию list
),
),
);
Yaf_Dispatcher::getInstance()->getRouter()->addConfig(
new Yaf_Config_Simple($config));
?>
Вывод приведённого примера будет похож на:
/* для http://yourdomain.com/user-list/22 * результатом маршрута будут следующие значения: */ array( "controller" => "user", "action" => "list", "module" => "index", //(по умолчанию) ) /** * и параметры запроса: */ array( "id" => 22, )
Пример #3 Пример использования класса Yaf_Route_Rewrite (начиная с 2.3.0)
<?php
/**
* Добавить переписать маршрут использовать результат поиска как имя м/к/д
*/
$config = array(
"name" => array(
"type" => "rewrite",
"match" => "/user-list/:a/:id", //совпадение только по /user-list/*
"route" => array(
'controller' => "user", //маршрут к контроллеру user,
'action' => ":a", //маршрут к действию :a
),
),
);
Yaf_Dispatcher::getInstance()->getRouter()->addConfig(
new Yaf_Config_Simple($config));
?>
Вывод приведённого примера будет похож на:
/* для http://yourdomain.com/user-list/list/22 * результатом маршрута будут следующие значения: */ array( "controller" => "user", "action" => "list", "module" => "index", //(по умолчанию) ) /** * и параметры запроса: */ array( "id" => 22, )