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);
|
|