array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'pt_BR', ), 'this' => array ( 0 => 'yaf-route-rewrite.construct.php', 1 => 'Yaf_Route_Rewrite::__construct', ), 'up' => array ( 0 => 'class.yaf-route-rewrite.php', 1 => 'Yaf_Route_Rewrite', ), 'prev' => array ( 0 => 'yaf-route-rewrite.assemble.php', 1 => 'Yaf_Route_Rewrite::assemble', ), 'next' => array ( 0 => 'yaf-route-rewrite.route.php', 1 => 'Yaf_Route_Rewrite::route', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'en', 'path' => 'reference/yaf/yaf_route_rewrite/construct.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(Yaf >=1.0.0)
Yaf_Route_Rewrite::__construct — Yaf_Route_Rewrite constructor
match
A pattern, will be used to match a request uri, if
it doesn't match, Yaf_Route_Rewrite will return
false
.
You can use :name style to name segments matched, and use * to match the rest of the URL segments.
route
When the match pattern matches the request uri, Yaf_Route_Rewrite will use this to decide which module/controller/action is the destination.
Either of module/controller/action in this array is optional, if you don't assign a specific value, it will be routed to default.
verify
Exemplo #1 Yaf_Route_Rewrite()example
<?php
/**
* Add a rewrite route to Yaf_Router route stack
*/
Yaf_Dispatcher::getInstance()->getRouter()->addRoute("name",
new Yaf_Route_rewrite(
"/product/:name/:id/*", //match request uri leading "/product"
array(
'controller' => "product", //route to product controller,
),
)
);
?>
O exemplo acima produzirá algo semelhante a:
/* for http://yourdomain.com/product/foo/22/foo/bar * route will result in following values: */ array( "controller" => "product", "module" => "index", //(default) "action" => "index", //(default) ) /** * and request parameters: */ array( "name" => "foo", "id" => 22, "foo" => bar )
Exemplo #2 Yaf_Route_Rewrite()example
<?php
/**
* Add a rewrite route to Yaf_Router route stack by calling addconfig
*/
$config = array(
"name" => array(
"type" => "rewrite", //Yaf_Route_Rewrite route
"match" => "/user-list/:id", //match only /user/list/?/
"route" => array(
'controller' => "user", //route to user controller,
'action' => "list", //route to list action
),
),
);
Yaf_Dispatcher::getInstance()->getRouter()->addConfig(
new Yaf_Config_Simple($config));
?>
O exemplo acima produzirá algo semelhante a:
/* for http://yourdomain.com/user-list/22 * route will result in following values: */ array( "controller" => "user", "action" => "list", "module" => "index", //(default) ) /** * and request parameters: */ array( "id" => 22, )
Exemplo #3 Yaf_Route_Rewrite(as of 2.3.0)()example
<?php
/**
* Add a rewrite route use match result as m/c/a name
*/
$config = array(
"name" => array(
"type" => "rewrite",
"match" => "/user-list/:a/:id", //match only /user-list/*
"route" => array(
'controller' => "user", //route to user controller,
'action' => ":a", //route to :a action
),
),
);
Yaf_Dispatcher::getInstance()->getRouter()->addConfig(
new Yaf_Config_Simple($config));
?>
O exemplo acima produzirá algo semelhante a:
/* for http://yourdomain.com/user-list/list/22 * route will result in following values: */ array( "controller" => "user", "action" => "list", "module" => "index", //(default) ) /** * and request parameters: */ array( "id" => 22, )