Yaf_Route_Regex::__construct

(Yaf >=1.0.0)

Yaf_Route_Regex::__constructConstructor de Yaf_Route_Regex

Descripción

public Yaf_Route_Regex::__construct ( string $match , array $route [, array $map [, array $verify [, string $reverse ]]] )

Parámetros

match

Un patrón de expresión regular completo, se usará para comparar un URI solicitado, si no coincide, Yaf_Route_Regex devolverá FALSE.

route

Cuando el patrón de comparación coincida con el URI solicitado, Yaf_Route_Regex lo usará para decidir qué m/c/a enrutar.

m/c/a en este array son opcionales, si no se asigna un valor específico, será enrutada al valor predeterminado.

map

Un array para asignar nombres a las capturas del resultado de comparación.

reverse

una cadena, usado para ensamblar url, ver Yaf_Route_Regex::assemble().

Nota:

este parametro se introdujo en 2.3.0

verify

Valores devueltos

Ejemplos

Ejemplo #1 Ejemplo de Yaf_Route_Regex()

<?php
   
/**
    * Añade una ruta de expresión regular a la pila de enrutamiento de Yaf_Router
    */
    
Yaf_Dispatcher::getInstance()->getRouter()->addRoute("name",
        new 
Yaf_Route_Regex(
           
"#^/product/([^/]+)/([^/])+#"//comparar los URI solicitados que empiecen por "/product"
           
array(
               
'controller' => "product",  //ruta al controlador product,
           
),
           array(
              
=> "name",   // ahora se puede llamar a $request->getParam("name")
              
=> "id",     // para obtener la primera captura del patrón de comparación.
           
)
        )
    );
?>

Ejemplo #2 Ejemplo de Yaf_Route_Regex(como en 2.3.0)()

<?php
   
/**
    * Usar el resultado de la busqueda como nombre MVC
    */
    
Yaf_Dispatcher::getInstance()->getRouter()->addRoute("name",
        new 
Yaf_Route_Regex(
           
"#^/product/([^/]+)/([^/])+#i"//buscar primera peticion uri "/product"
           
array(
              
'controller' => ":name"// ruta a :name, el cual es $1 en el resultado de busqueda como nombre de controllador
           
),
           array(
              
=> "name",   // ahora puede llamar a $request->getParam("name")
              
=> "id",     // para obtener la primera coincidencia en el patron de busqueda.
           
)
        )
    );
?>

Ejemplo #3 Ejemplo de Yaf_Route_Regex y el nombre de la zona de captura (a partir de 2.3.0)()

<?php
   
/**
    * Usar el resultado de la coincidencia como nombre del MVC
    */
    
Yaf_Dispatcher::getInstance()->getRouter()->addRoute("name",
        new 
Yaf_Route_Regex(
           
"#^/product/(?<name>[^/]+)/([^/])+#i"//solicitud de coincidencia uri leading "/product"
           
array(
           
'controller' => ":name"// ruta a :name,
                                    // que se denomina "nombre" del grupo de captura en el resultado de la coincidencia como nombre del controlador
           
),
           array(
              
=> "id",     // para obtener la primera captura en el patrón de coincidencia.
           
)
        )
    );
?>

Ejemplo #4 Ejemplo de Yaf_Route_Regex()

<?php
   
/**
    * Add a regex route to Yaf_Router route stack by calling addconfig
    */
    
$config = array(
        
"name" => array(
           
"type"  => "regex",          //ruta Yaf_Route_Regex
           
"match" => "#(.*)#",         //comparar URIs solicitados arbitrarios
           
"route" => array(
               
'controller' => "product",  //ruta al controlador product,
               
'action'     => "dummy",    //ruta a una acción sin sentido
           
),
           
"map" => array(
              
=> "uri",   // ahora se puede llamar a $request->getParam("uri")
           
),
        ),
    );
    
Yaf_Dispatcher::getInstance()->getRouter()->addConfig(
        new 
Yaf_Config_Simple($config));
?>

Ver también