Yet Another Framework Yaf_Route_Rewrite::__construct
(Yaf >=1.0.0)
Yaf_Route_Rewrite::__construct — Yaf_Route_Rewrite constructor
설명
public Yaf_Route_Rewrite::__construct(string $match
, array $route
, array $verify
= ?)
매개변수
match
- 패턴은 요청 URI와 일치하는 데 사용되며 일치하지 않으면 Yaf_Route_Rewrite가
false
를 반환합니다.:name 스타일을 사용하여 일치하는 세그먼트의 이름을 지정하고 *를 사용하여 나머지 URL 세그먼트와 일치시킬 수 있습니다.
route
- 일치 패턴이 요청 uri와 일치하면 Yaf_Route_Rewrite는 이를 사용하여 대상이 어느 모듈/컨트롤러/액션인지 결정합니다.
이 배열의 모듈/컨트롤러/액션 중 하나는 선택 사항이며 특정 값을 지정하지 않으면 기본값으로 라우팅됩니다.
verify
반환 값
Examples
예제 #1 Yaf_Route_Rewrite() 예제
<?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,
),
)
);
?>
위의 예는 다음과 유사한 결과를 출력합니다.
/* 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 )
예제 #2 Yaf_Route_Rewrite() 예제
<?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));
?>
위의 예는 다음과 유사한 결과를 출력합니다.
/* 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, )
예제 #3 Yaf_Route_Rewrite(as of 2.3.0)() 예제
<?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));
?>
위의 예는 다음과 유사한 결과를 출력합니다.
/* 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, )
기타
- Yaf_Router::addRoute() - 라우터에 새 경로 추가
- Yaf_Router::addConfig() - 라우터에 구성 정의 경로 추가
- Yaf_Route_Static
- Yaf_Route_Supervar
- Yaf_Route_Simple
- Yaf_Route_Regex
- Yaf_Route_Map