(Yaf >=1.0.0)
Yaf_Route_Rewrite::__construct — Constructeur Yaf_Route_Rewrite
$match, array $route, array $verify = ?)
match
      Un masque à utiliser sur une requête URI.
      Si aucune correspondance n'y est trouvée, Yaf_Route_Rewrite
      retournera false.
     
Vous pouvez utiliser le style :name pour nommer le segment recherché, et utiliser le caractère * pour récupérer le reste du segment de l'URL.
routeLorsque le masque trouve une correspondance sur la requête URI, Yaf_Route_Rewrite utilisera ce paramètre pour savoir quel module/controller/action doit être routé.
Les éléments du tableau module/controller/action sont optionnels, si vous ne les assignez pas en une valeur spécifique, ils seront routés vers la cible par défaut.
verify
Exemple #1 Exemple avec Yaf_Route_Rewrite()
<?php
   /**
    * Ajoute une route de réécriture à la pile de routes de Yaf_Router
    */
    Yaf_Dispatcher::getInstance()->getRouter()->addRoute("name",
        new Yaf_Route_rewrite(
           "/product/:name/:id/*", //correspond à la requête URI "/product"
           array(
               'controller' => "product",  //route vers le controlleur produit,
           ),
        )
    );
?>
Résultat de l'exemple ci-dessus est similaire à :
/* Pour http://yourdomain.com/product/foo/22/foo/bar * la route résultante aura les valeurs suivantes : */ array( "controller" => "product", "module" => "index", //(default) "action" => "index", //(default) ) /** * et les paramètres de la requête : */ array( "name" => "foo", "id" => 22, "foo" => bar )
Exemple #2 Exemple avec Yaf_Route_Rewrite()
<?php
   /**
    * Ajoute une route de réécriture à la pile de route Yaf_Router
    * en appelant addconfig
    */
    $config = array(
        "name" => array(
           "type"  => "rewrite",        //route Yaf_Route_Rewrite
           "match" => "/user-list/:id", //correspond uniquement à /user/list/?/
           "route" => array(
               'controller' => "user",  //route vers le contrôleur utilisateur
               'action'     => "list",  //route vers la liste des actions
           ),
        ),
    );
    Yaf_Dispatcher::getInstance()->getRouter()->addConfig(
        new Yaf_Config_Simple($config));
?>
Résultat de l'exemple ci-dessus est similaire à :
/* Pour http://yourdomain.com/user-list/22 * la route résultera en les valeurs suivantes : */ array( "controller" => "user", "action" => "list", "module" => "index", //(default) ) /** * et les paramètres de la requête : */ array( "id" => 22, )
Exemple #3 Exemple avec Yaf_Route_Rewrite (depuis 2.3.0)()
<?php
   /**
    * Ajout d'une route de ré-écriture utilisée pour chercher un résultat du type m/c/a
    */
    $config = array(
        "name" => array(
           "type"  => "rewrite",        
           "match" => "/user-list/:a/:id", //correspond uniquement à /user-list/*
           "route" => array(
               'controller' => "user",   //route vers le contrôleur user,
               'action'     => ":a",     //route vers l'action :a
           ),
        ),
    );
    Yaf_Dispatcher::getInstance()->getRouter()->addConfig(
        new Yaf_Config_Simple($config));
?>
Résultat de l'exemple ci-dessus est similaire à :
/* pour http://yourdomain.com/user-list/list/22 * la route va correspondre aux valeurs suivantes : */ array( "controller" => "user", "action" => "list", "module" => "index", //(par défaut) ) /** * et les paramètres demandés : */ array( "id" => 22, )