Yaf_Route_Rewrite::__construct

(Yaf >=1.0.0)

Yaf_Route_Rewrite::__constructКонструктор класса Yaf_Route_Rewrite

Описание

public Yaf_Route_Rewrite::__construct ( string $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,
)

Смотрите также