Zend Framework 1.7
    
    
        Lors de la migration d'un version précédente vers Zend Framework 1.7 ou plus récent
        vous devriez prendre note de ce qui suit.
     
    Zend_Controller
        
        Changement dans l'interface Dispatcher
            
            
                Les utilisateurs ont portés l'attention sur le fait que
                Zend_Controller_Action_Helper_ViewRenderer utilisait une
                méthode de la classe abstraite du distributeur standard qui n'était pas présente
                dans l'interface Dispatcher.La méthode suivante a donc été ajoutée pour s'assurer
                que les distributeurs personnalisés continueront à fonctionner avec les
                implémentations embarquées :
             
            
                - 
                    
                         formatModuleName() : devrait être utilisé pour prendre
                        un nom de contrôleur brut, comme un qui aurait été embarqué dans un objet
                        requête, et pour le formater en un nom de classe approprié qu'une classe
                        étendant Zend_Controller_Action pourra
                        utiliser.
                     
                 
             
         
     
    Zend_File_Transfer
        
        Changements quand vous utilisez des filtres ou des validateurs
            
            
                Certaines remarques des utilisateurs indiquaient que les validateurs de
                Zend_File_Transfer ne fonctionnaient pas correctement avec
                Zend_Config dû au fait qu'ils n'utilisait pas de tableaux
                nommés.
             
            
                De plus, tous les filtres et validateurs de
                Zend_File_Transfer ont été réécrits. Même si les anciennes
                signatures continuent à fonctionner, elles ont été marqués comme dépréciées et
                émettent une notice PHP vous informant de faire le changement.
             
            
                La liste suivante vous montre les changements à réaliser pour une utilisation
                appropriée des paramètres.
             
            Filtre Rename
                
                
                    - 
                        
                            Ancienne API : Zend_Filter_File_Rename($oldfile,
                            $newfile, $overwrite)
                         
                     
                    - 
                        
                            Nouvelle API :
                             Zend_Filter_File_Rename($options) où
                            $options accepte un tableau avec les clés suivantes :
                            source est équivalent à $oldfile,
                            target est équivalent à $newfile,
                            overwrite est équivalent à
                            $overwrite.
                         
                     
                 
                Example #1 Changer le filtre rename entre 1.6 et 1.7  
                    
                    // Exemple pour 1.6  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addFilter('Rename',  
                   array('/path/to/oldfile',  '/path/to/newfile',  true));   
   
// Même exemple pour 1.7  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addFilter('Rename',  
                   array('source' =>  '/path/to/oldfile',   
                         'target' => '/path/to/newfile',  
                         'overwrite' => true)); 
  
                 
             
            Validateur Count
                
                
                    - 
                        
                            Ancienne API : Zend_Validate_File_Count($min,
                            $max)
                         
                     
                    - 
                        
                            Nouvelle API :
                             Zend_Validate_File_Count($options) où
                            $options accepte un tableau avec les clés suivantes :
                            min est équivalent à $min,
                            max est équivalent à $max.
                         
                     
                 
                Example #2 Changer le validateur count entre 1.6 et 1.7  
                    
                    // Exemple pour 1.6  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addValidator('Count',  
   
// Même exemple pour 1.7  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addValidator('Count',  
                      false,  
                            'max' => 3)); 
  
                 
             
            Validateur Extension
                
                
                    - 
                        
                            Ancienne API : Zend_Validate_File_Extension($extension,
                            $case)
                         
                     
                    - 
                        
                            Nouvelle API :
                             Zend_Validate_File_Extension($options) où
                            $options accepte un tableau avec les clés suivantes :
                            * est équivalent à $extension et peut
                            avoir tout autre clé, case est équivalent à
                            $case.
                         
                     
                 
                Example #3 Changer le validateur extension entre 1.6 et 1.7  
                    
                    // Exemple pour 1.6  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addValidator('Extension',  
                   array('jpg,gif,bmp',  true));   
   
// Même exemple pour 1.7  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addValidator('Extension',  
                      false,  
                      array('extension1' =>  'jpg,gif,bmp',   
                            'case' => true)); 
  
                 
             
            Validateur FilesSize
                
                
                    - 
                        
                            Ancienne API : Zend_Validate_File_FilesSize($min, $max,
                            $bytestring)
                         
                     
                    - 
                        
                            Nouvelle API :
                             Zend_Validate_File_FilesSize($options) où
                            $options accepte un tableau avec les clés suivantes :
                            min est équivalent à $min,
                            max est équivalent à $max,
                            bytestring est équivalent à
                            $bytestring.
                         
                     
                 
                
                    De plus la signature de la méthode  useByteString() a changé.
                    Elle peut être seulement utilisée pour tester si le validateur prévoie
                    d'utiliser les chaînes lisibles ou la valeur brute dans les messages générées.
                    Pour paramétrer la valeur de cette option, utilisez la méthode
                     setUseByteString().
                 
                Example #4 Changer le validateur filessize entre 1.6 et 1.7  
                    
                    // Exemple pour 1.6  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addValidator('FilesSize',  
                      array(100,  10000,  true));   
   
// Même exemple pour 1.7  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addValidator('FilesSize',  
                      false,  
                            'max' => 10000,  
                            'bytestring' => true));  
   
// Exemple pour 1.6  
$upload->useByteString(true); // set flag  
   
// Même exemple pour 1.7  
$upload->setUseByteSting(true); // set flag 
  
                 
             
            Validateur Hash
                
                
                    - 
                        
                            Ancienne API : Zend_Validate_File_Hash($hash,
                            $algorithm)
                         
                     
                    - 
                        
                            Nouvelle API :
                             Zend_Validate_File_Hash($options) où
                            $options accepte un tableau avec les clés suivantes :
                            * est équivalent à $hash et peut avoir
                            tout autre clé, algorithm est équivalent à
                            $algorithm.
                         
                     
                 
                Example #5 Changer le validateur hash entre 1.6 et 1.7  
                    
                    // Exemple pour 1.6  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addValidator('Hash',  
   
// Même exemple pour 1.7  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addValidator('Hash',  
                      false,  
                      array('hash1' =>  '12345',   
                            'algorithm' => 'md5')); 
  
                 
             
            Validateur ImageSize
                
                
                    - 
                        
                            Ancienne API : Zend_Validate_File_ImageSize($minwidth,
                            $minheight, $maxwidth, $maxheight)
                         
                     
                    - 
                        
                            Nouvelle API :
                             Zend_Validate_File_FilesSize($options) où
                            $options accepte un tableau avec les clés suivantes :
                            minwidth est équivalent à $minwidth,
                            maxwidth est équivalent à $maxwidth,
                            minheight est équivalent à $minheight,
                            maxheight est équivalent à
                            $maxheight.
                         
                     
                 
                Example #6 Changer le validateur imagesize entre 1.6 et 1.7  
                    
                    // Exemple pour 1.6  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addValidator('ImageSize',  
                      array(10,  10,  100,  100));   
   
// Même exemple pour 1.7  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addValidator('ImageSize',  
                      false,  
                            'minheight' => 10,  
                            'maxwidth' => 100,  
                            'maxheight' => 100)); 
  
                 
             
            Validateur Size
                
                
                    - 
                        
                            Ancienne API : Zend_Validate_File_Size($min, $max,
                            $bytestring)
                         
                     
                    - 
                        
                            Nouvelle API :
                             Zend_Validate_File_Size($options) où
                            $options accepte un tableau avec les clés suivantes :
                            min est équivalent à $min,
                            max est équivalent à $max,
                            bytestring est équivalent à
                            $bytestring
                         
                     
                 
                Example #7 Changer le validateur size entre 1.6 et 1.7  
                    
                    // Exemple pour 1.6  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addValidator('Size',  
                      array(100,  10000,  true));   
   
// Même exemple pour 1.7  
$upload = new Zend_File_Transfer_Adapter_Http();  
$upload->addValidator('Size',  
                      false,  
                            'max' => 10000,  
                            'bytestring' => true)); 
  
                 
             
         
     
    Zend_Locale
        
        Changement dans l'utilisation de isLocale()
            
            
                Conformément aux standards de codage  isLocale() a été changé pour
                retourner un booléen. Dans les versions précédentes une chaîne était retournée lors
                du succès. Pour la version 1.7 un mode de compatibilité a été ajouté qui vous permet
                d'utiliser l'ancien comportement (avec une chaîne retournée), mais ceci émet un
                warning pour vous informer de changer vers le nouveau comportement. Le reroutage que
                l'ancien comportement de  isLocale() pouvait avoir à faire n'est plus
                nécessaire car tous les composants de l'I18N traiteront maintenant eux-mêmes le
                reroutage.
             
            
                Pour migrer vos scripts vers la nouvelle API, utilisez simplement la méthode
                décrite ci-dessous.
             
            Example #8 Comment changer l'appel de isLocale() de 1.6 vers 1.7 ?  
                
                // Exemple pour ZF 1.6  
if ($locale = Zend_Locale::isLocale($locale)) {  
    // faire qqch  
}  
   
// Même exemple pour ZF 1.7  
   
// Vous devez changer le mode de compatibilité pour empêcher l'émission de warning  
// Mais ceci peut être fait dans votre bootstrap  
Zend_Locale::$compatibilityMode = false;  
   
if (Zend_Locale::isLocale($locale)) {  
} 
  
                
                    Notez que vous pouvez utiliser le second paramètre pour voir si la locale
                    est correcte sans nécessiter de reroutage.
                  
                // Exemple pour ZF 1.6  
if ($locale = Zend_Locale::isLocale($locale, false)) {  
    // do something  
}  
   
// Même exemple pour ZF 1.7  
   
// Vous devez changer le mode de compatibilité pour empêcher l'émission de warning  
// Mais ceci peut être fait dans votre bootstrap  
Zend_Locale::$compatibilityMode = false;  
   
if (Zend_Locale::isLocale($locale, false)) {  
    if (Zend_Locale::isLocale($locale, true)) {  
        // pas de locale du tout  
    }  
   
    // original string is no locale but can be rerouted  
} 
  
             
         
        Changement dans l'utilisation de getDefault()
            
            
                La signification de la méthode  getDefault() a été changé étant
                donné que nous avons intégré une locale de framework qui peut être paramétrée avec
                 setDefault(). Ceci ne renvoie plus la chaîne de la locale mais
                seulement la locale du framework.
             
            
                Pour migrer vos scripts vers la nouvelle API, utilisez simplement la méthode
                décrite ci-dessous.
             
            Example #9 Comment changer l'appel de getDefaut() de 1.6 vers 1.7 ?  
                
                // Exemple pour ZF 1.6  
$locales = $locale->getDefault(Zend_Locale::BROWSER);  
   
// Même exemple pour ZF 1.7  
   
// Vous devez changer le mode de compatibilité pour empêcher l'émission de warning  
// Mais ceci peut être fait dans votre bootstrap  
Zend_Locale::$compatibilityMode = false;  
   
$locale = Zend_Locale::getOrder(Zend_Locale::BROWSER); 
  
                
                    Notez que le second paramètre de l'ancienne implémentation de
                     getDefault() n'est plus disponible non plus, mais les valeurs
                    retournées sont les mêmes.
                  
             
            Note: 
                
                    Par défaut l'ancien comportement est toujours actif, mais émet un warning.
                    Quand vous avez changé votre code vers le nouveau comportement, vous devriez
                    aussi changer le mode de compatibilité à FALSE ainsi aucun nouveau
                    warning ne sera émis.
                 
              
         
     
    Zend_Translate
        
        Paramétrer les langues
            
            
                Lors de l'utilisation de la détection automatique des langues, ou du réglage
                manuel des langues de Zend_Translate, vous avez peut-être
                remarqué que de temps en temps une notice est envoyée concernant le non-ajout de
                traductions vides. Dans certaines versions précédentes, une exception était levée
                dans certains cas.
             
            
                Ceci intervient quand un utilisateur requête une langue non existante, vous
                n'avez alors aucun moyen simple de détecter ce qui ne va pas. Nous avons donc ajouté
                ces notices qui apparaîtront dans votre historisation et qui vous diront qu'un
                utilisateur a requêté une langue que vous ne supportez pas. Notez bien que votre
                code, même si une notice est déclenchée, fonctionnera sans problèmes.
             
            
                Mais quand vous utilisez votre propre gestionnaire d'erreur ou d'exception,
                comme xDebug, toutes les notices vous seront retournées, même si ce n'est pas votre
                intention initiale. Ceci est du au fait, que ces gestionnaires surchargent tous les
                réglages internes de PHP.
             
            
                Pour vous affranchir de ces notices, vous pouvez simplement paramétrer la
                nouvelle option disableNotices à TRUE, sa valeur par
                défaut étant FALSE.
             
            Example #10 Paramétrer les langues sans avoir de notices  
                
                
                    Assumons que "fr" soit disponible et qu'un utilisateur
                    requête pour "de" qui ne fait pas partie de votre portefeuille de
                    traductions.
                  
                $language = new Zend_Translate('gettext',  
                               '/chemin/vers/les/traductions',  
                               'auto'); 
  
                
                    Dans ce cas nous aurons une notice indiquant la non-disponibilité de la
                    langue "de". Ajoutez simplement l'option et les notices seront
                    désactivées.
                  
                $language = new Zend_Translate('gettext',  
                               '/chemin/vers/les/traductions',  
                               'auto',  
                               array('disableNotices' =>  true));  
  
             
         
     
    Zend_View
        
        Note: 
            
                Les changements de l'API de Zend_View sont seulement
                notables pour vous si vous mettez à jour vers les version 1.7.5 ou plus récent.
             
          
        
            Avant la version 1.7.5, l'équipe de Zend Framework a été avertie d'une faille
            potentielle d'inclusion de fichier local ("Local File Inclusion" (LFI)) dans la méthode
             Zend_View::render(). Avant 1.7.5, la méthode acceptait par défaut
            la possibilité de spécifier des scripts de vue comportant des indications de dossier
            parent (comme, "../" ou "..\"). Ceci ouvre la possibilité à une attaque LFI si des
            données utilisateurs non filtrées sont passées directement à la méthode
             render():
         
        // Ici, $_GET['foobar'] = '../../../../etc/passwd'  
echo $view-> render($_GET['foobar']);  // inclusion LFI 
  
        
            Zend_View émet maintenant une exception dans un tel
            cas.
         
        Désactiver la protection LFI de render()
            
            
                Comme des développeurs utilisaient de telles notations, mais qui n'étaient
                pas des données en provenance de l'extérieur, un drapeau
                spécial a été crée, il permet de désactiver la protection. Pour manipuler ce
                drapeau, il existe 2 moyens : le paramètre 'lfiProtectionOn' du constructeur de
                votre vue, ou encore la méthode  setLfiProtection().
             
            // Désactivation de la protection par le constructeur  
$view =  new Zend_View (array('lfiProtectionOn' =>  false));   
   
// Désactivation de la protection par la méthode dédiée  
$view = new Zend_View();  
$view->setLfiProtection(false); 
  
         
     
 
         
            
 | 
         
 
  |