Zend Framework 0.6
    
    
        Lors de la migration d'un version précédente vers Zend Framework 0.6 ou plus récent
        vous devriez prendre note de ce qui suit.
     
    Zend_Controller
        
        
            L'utilisation de base des composants MVC n'a pas changé ; vous pouvez toujours
            faire comme suit :
         
        Zend_Controller_Front::run('/chemin/vers/controleurs'); 
  
        /* -- créer un routeur -- */  
$router = new Zend_Controller_RewriteRouter();  
$router-> addRoute('user',  'user/:username',  array('controller' =>  'user',   
'action' => 'info'));  
   
/* -- l'affecter à un contrôleur -- */  
$ctrl = Zend_Controller_Front::getInstance();  
$ctrl->setRouter($router);  
   
/* -- régler le répertoire des contrôleurs et distribuer -- */  
$ctrl->setControllerDirectory('/chemin/vers/controleurs');  
$ctrl->dispatch(); 
  
        
            Nous encourageons l'utilisation de l'objet Réponse pour agréger le contenu et les
            en-têtes. Ceci permet un basculement plus flexible entre les formats d'affichage (par
            exemple, JSON ou XML au lieu de XHTML) dans vos applications. Par défaut,
             dispatch() va effectuer le rendu de la réponse, envoyant à la fois les
            en-têtes et tout contenu. Vous pouvez aussi avoir le contrôleur frontal qui retourne la
            réponse en utilisant  returnResponse(), et qui ensuite effectue le rendu de
            la réponse suivant votre propre logique. Une version future du contrôleur frontal peut
            mettre en application l'utilisation de l'objet Réponse via la
            » bufferisation de
            sortie.
         
        
            Il existe beaucoup d'autres fonctionnalités qui étendent l'API existante, et
            celles-ci sont décrites dans la documentation.
         
        
            Le changement le plus important auquel vous devrez faire attention apparaîtra
            quand vous tenterez de sous-classer les différents composants. La clé se trouve
            ci-dessous :
         
        
            - 
                
                     Zend_Controller_Front::dispatch() intercepte par
                    défaut les exceptions dans l'objet réponse, et ne les affiche pas, afin
                    d'éviter l'affichage d'information sensible du système. Vous pouvez surcharger
                    ceci de différentes manières :
                 
                
             
            - 
                
                     Zend_Controller_Dispatcher_Interface::dispatch()
                    accepte maintenant et retourne un objet
                    L'objet Requête au lieu d'un élément du
                    distributeur.
                 
             
            - 
                
                     Zend_Controller_Router_Interface::route() accepte
                    maintenant et retourne un objet L'objet Requête au
                    lieu d'un élément du distributeur.
                 
             
            - 
                
                    Les changements de Zend_Controller_Action
                    incluent :
                 
                
                    - 
                        
                            Le constructeur accepte maintenant exactement trois arguments,
                            Zend_Controller_Request_Abstract $request,
                            Zend_Controller_Response_Abstract $response, et
                            le tableau facultatif $params.
                             Zend_Controller_Action::__construct() les
                            utilise pour affecter la requête, la réponse, et les propriétés
                            invokeArgs de l'objet, et si vous devez surcharger le
                            constructeur, vous devez faire de même. La meilleure solution est
                            d'utiliser la méthode  init() pour réaliser toute
                            configuration de l'instance, puisque cette méthode est appelée en tant
                            que action finale du constructeur.
                         
                     
                    - 
                        
                             run() n'est plus défini en tant qu'élément final,
                            mais n'est pas non plus utilisé par le contrôleur frontal ; son seul
                            but apparaît lors de l'utilisation de la classe en tant que contrôleur
                            de page. Il prend maintenant deux arguments facultatifs, un
                            Zend_Controller_Request_Abstract $request et un
                            Zend_Controller_Response_Abstract
                            $response.
                         
                     
                    - 
                        
                             indexAction() ne nécessite plus d'être défini, mais
                            est recommandé en tant qu'action par défaut. Ceci permet lors de
                            l'utilisation de RewriteRouter et des contrôleurs d'action
                            de spécifier différentes méthodes d'action par défaut.
                         
                     
                    - 
                        
                             __call() peut être surchargé pour gérer
                            automatiquement les actions non définies.
                         
                     
                    - 
                        
                             _redirect() prend maintenant un second paramètre
                            facultatif, le code HTTP à retourner avec la redirection, et un
                            troisième paramètre optionnel, $prependBase, qui peut
                            indiquer que l'URL de base enregistré avec l'objet requête peut être
                            ajouté en tant que suffixe à l'URL spécifié.
                         
                     
                    - 
                        
                            La propriété _action n'existe plus. Cette propriété
                            était un Zend_Controller_Dispatcher_Token, qui
                            n'existe plus maintenant. Le seul but de cet élément est de fournir
                            l'information concernant le contrôleur, l'action et les paramètres
                            d'URL de la requête. Cette information est maintenant disponible dans
                            l'objet requête, et peut être interrogé comme ceci :
                         
                        // Récupère le nom de controleur de la requête  
// L'accès se fait via : $this->_action->getControllerName().  
// L'exemple ci-dessous utilise getRequest(), bien que vous pourriez  
// accéder directement à la propriété $_request ;  
// l'utilisation de getRequest() est recommandée puisque la classe  
// parente peut surcharger l'accès à l'objet requête.  
$controller = $this->getRequest()->getControllerName();  
   
// Recupere le nom de l'action de la requete  
// L'acces se fait via : $this->_action->getActionName().  
$action = $this->getRequest()->getActionName();  
   
// Recupere les parametres de la requete  
// Ceci n'a pas changé ; les méthodes _getParams() et _getParam()  
// relaient simplement l'objet requete maintenant.  
$params = $this->_getParams();  
$foo = $this->_getParam('foo', 'default');  
// parametre de la requete 'foo', en utilisant 'default'  
// en tant que valeur par défaut si aucune valeur n'est trouvée 
  
                     
                    - 
                        
                             noRouteAction() a été effacée. La manière appropriée
                            de gérer les méthodes d'actions non-existantes est de les router vers
                            une action par défaut en utilisant  __call() :
                         
                        public function __call($method, $args)  
{  
    // Si la méthode requetee ne correspond a aucune methode 'Action',  
    // on renvoie vers la méthode d'action par défaut :  
    if ('Action' ==  substr($method,  -6)) {  
        return $this->defaultAction();  
    }  
   
    throw new Zend_Controller_Exception('Appel de methode invalide');  
} 
  
                     
                 
             
            - 
                
                     Zend_Controller_RewriteRouter::setRewriteBase() a
                    été effacée. Utilisez plutôt
                     Zend_Controller_Front::setBaseUrl() (ou
                    Zend_Controller_Request_Http::setBaseUrl(), si vous utilisez cette classe de
                    requête).
                 
             
            - 
                
                    Zend_Controller_Plugin_Interface a été remplacée
                    par Zend_Controller_Plugin_Abstract. Toutes les méthodes
                    acceptent et retournent maintenant un objet
                    L'objet Requête au lieu d'un élément du
                    distributeur.
                 
             
         
     
 
         
            
 | 
         
 
  |