Zend_Validate-EmailAddress.xml 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. <!-- EN-Revision: 12150 -->
  2. <sect2 id="zend.validate.set.email_address">
  3. <title>EmailAddress</title>
  4. <para><classname>Zend_Validate_EmailAddress</classname> permet de valider une adresse émail. Ce validateur éclate d'abord
  5. l'adresse émail entre partie locale et domaine et essaie de valider ces deux parties conformément aux spécifications
  6. des adresses émail et des noms de domaine.</para>
  7. <para><emphasis role="strong">Utilisation de base</emphasis></para>
  8. <para>Exemple basique : <programlisting role="php"><![CDATA[
  9. $validateur = new Zend_Validate_EmailAddress();
  10. if ($validateur->isValid($email)) {
  11. // l'email est valide
  12. } else {
  13. // l'email est invalide ; afficher pourquoi
  14. foreach ($validateur->getMessages() as $message) {
  15. echo "$message\n";
  16. }
  17. }
  18. ]]></programlisting> Ceci validera l'adresse émail <code>$email</code> et, en cas d'échec, fournira des messages
  19. d'erreur informatifs via <code>$validator-&gt;getMessages()</code>.</para>
  20. <para><emphasis role="strong">Parties locales complexes</emphasis></para>
  21. <para><classname>Zend_Validate_EmailAddress</classname> validera toute adresse émail conforme à la RFC2822. Comme par exemple
  22. <code>bob@domaine.com</code>, <code>bob+jones@domaine.fr</code>, <code>"bob@jones"@domaine.com</code> et <code>"bob
  23. jones"@domaine.com</code>. Quelques formats d'émail obsolètes ne seront pas validés (comme tout émail contenant un
  24. retour chariot ou un caractère "\").</para>
  25. <para><emphasis role="strong">Validation de différents types de noms de domaine</emphasis></para>
  26. <para>La partie domaine d'une adresse émail est validée via <link
  27. linkend="zend.validate.set.hostname"><classname>Zend_Validate_Hostname</classname></link>. Par défaut, seules les domaines
  28. qualifiés sous la forme <code>domaine.com</code> sont acceptés, même si, il vous est possible d'accepter les
  29. adresses IP et les domaines locaux également.</para>
  30. <para>Afin de réaliser cette opération, il vous faut instancier <classname>Zend_Validate_EmailAddress</classname> en lui
  31. passant un paramètre indiquant le type de nom de domaine à accepter. Les détails sont disponibles dans
  32. <classname>Zend_Validate_EmailAddress</classname> mais vous trouverez ci-dessous un exemple illustrant comment accepter les
  33. noms de domaines qualifiés et les hôtes locaux : <programlisting role="php"><![CDATA[
  34. $validateur = new Zend_Validate_EmailAddress(Zend_Validate_Hostname::ALLOW_DNS | Zend_Validate_Hostname::ALLOW_LOCAL);
  35. if ($validateur->isValid($email)) {
  36. // l'email est valide
  37. } else {
  38. // l'email est invalide ; afficher pourquoi
  39. foreach ($validateur->getMessages() as $message) {
  40. echo "$message\n";
  41. }
  42. }
  43. ]]></programlisting></para>
  44. <para><emphasis role="strong">Vérification que le nom de domaine accepte réellement l'émail</emphasis></para>
  45. <para>Le fait qu'une adresse électronique est dans un format correct, ne signifie pas nécessairement que l'adresse
  46. électronique existe en réalité. Pour aider résoudre ce problème, vous pouvez utiliser la validation MX pour vérifier
  47. si une entrée MX (l'émail) existe dans le l'enregistrement du DNS pour le nom de domaine de l'émail. Cela vous dit
  48. que le nom de domaine accepte l'émail, mais ne vous dit pas que l'adresse électronique elle-même est valable.</para>
  49. <para>La vérification MX n'est pas active par défaut et est seulement supporté par des plates-formes UNIX pour
  50. l'instant. Pour activer la vérification MX vous pouvez passer un deuxième paramètre au constructeur
  51. <classname>Zend_Validate_EmailAddress</classname>. <programlisting role="php"><![CDATA[
  52. $validator =
  53. new Zend_Validate_EmailAddress(Zend_Validate_Hostname::ALLOW_DNS,
  54. true);
  55. ]]></programlisting>
  56. Alternativement vous pouvez passer soit <code>true</code> soit <code>false</code> à
  57. <code>$validator-&gt;setValidateMx()</code> pour activer ou désactiver la validation MX.</para>
  58. <para>En activant ce paramètre, les fonctions de réseau seront utilisés pour vérifier la présence d'un
  59. enregistrement MX sur le nom de domaine de l'adresse électronique que vous voulez valider. Faîtes cependant
  60. attention, cela ralentira probablement votre scénario.</para>
  61. <para><emphasis role="strong">Valider les noms de domaines internationaux</emphasis></para>
  62. <para><classname>Zend_Validate_EmailAddress</classname> peut aussi vérifier les caractères internationaux qui existent dans
  63. quelques domaines. Ceci est connu comme le support de Nom de Domaine International (IDN). Celui-ci est activé par
  64. défaut, quoique vous puissiez le mettre hors service en changeant le paramètre via l'objet interne
  65. <classname>Zend_Validate_Hostname</classname> qui existe dans <classname>Zend_Validate_EmailAddress</classname>. <programlisting
  66. role="php"><![CDATA[
  67. $validator->hostnameValidator->setValidateIdn(false);
  68. ]]></programlisting> De plus amples
  69. informations concernant l'utilisation de <code>setValidateIdn()</code> sont présentes dans la <link
  70. linkend="zend.validate.set.hostname">documentation de <classname>Zend_Validate_Hostname</classname></link>.</para>
  71. <para>Notez cependant que les IDNs sont seulement validés si vous autorisez la validation des nom de
  72. domaines.</para>
  73. <para><emphasis role="strong">Validation des "Top Level Domains"</emphasis></para>
  74. <para>Par défaut un nom de domaine sera vérifié grâce à une liste de TLDs connus. Ceci est activé par défaut,
  75. quoique vous puissiez le mettre hors service en changeant le paramètre via l'objet
  76. <classname>Zend_Validate_Hostname</classname> interne qui existe dans <classname>Zend_Validate_EmailAddress</classname>. <programlisting
  77. role="php"><![CDATA[
  78. $validator->hostnameValidator->setValidateTld(false);
  79. ]]></programlisting> De plus amples
  80. informations concernant l'utilisation de <code>setValidateTld()</code> sont présentes dans la <link
  81. linkend="zend.validate.set.hostname">documentation de <classname>Zend_Validate_Hostname</classname></link>.</para>
  82. <para>Notez cependant que les TLDs sont seulement validés si vous autorisez la validation des nom de
  83. domaines.</para>
  84. </sect2>