Yaf_Route_Rewrite::__construct
(Yaf >=1.0.0)
Yaf_Route_Rewrite::__construct — Конструктор класса Yaf_Route_Rewrite
Описание
$match
, array $route
, array $verify
= ?
)
Список параметров
-
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(as of 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, )
Смотрите также
- Yaf_Router::addRoute() - Добавляет новый маршрут в маршрутизатор
- Yaf_Router::addConfig() - Добавляет настроенные маршруты в маршрутизатор
- Yaf_Route_Static
- Yaf_Route_Supervar
- Yaf_Route_Simple
- Yaf_Route_Regex
- Yaf_Route_Map