Zend_Validate-EmailAddress.xml 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. <sect2 id="zend.validate.set.email_address">
  2. <title>Dirección de Email</title>
  3. <para>
  4. <code>Zend_Validate_EmailAddress</code> Le permite validar una dirección
  5. de email. El validador primero divide la dirección de email en la parte
  6. local @ nombre de host e intenta igualar a estos contra especificaciones
  7. conocidas para direcciones y nombres de host para el correo electrónico.
  8. </para>
  9. <para>
  10. <emphasis role="strong">Utilización básica</emphasis>
  11. </para>
  12. <para>
  13. Un ejemplo básico de uso se ve a continuación:
  14. <programlisting role="php"><![CDATA[
  15. $validator = new Zend_Validate_EmailAddress();
  16. if ($validator->isValid($email)) {
  17. // El email parece ser válido
  18. } else {
  19. // El email es inválido; muestre las razones
  20. foreach ($validator->getMessages() as $message) {
  21. echo "$message\n";
  22. }
  23. }
  24. ]]>
  25. </programlisting>
  26. Esto coincide con el correo electrónico <code>$email</code> y si fracasa,
  27. alimenta <code>$validator->getMessages()</code> con mensajes de error útiles.
  28. </para>
  29. <para>
  30. <emphasis role="strong">Partes locales complejas</emphasis>
  31. </para>
  32. <para>
  33. <code>Zend_Validate_EmailAddress</code> se comparará con cualquier
  34. dirección de correo válida de acuardo a RFC2822.
  35. Por ejemplo, correos electrónicos válidos incluyen <code>bob@domain.com</code> ,
  36. <code>bob+jones@domain.us</code> , <code>"bob@jones"@domain.com</code> y
  37. <code>"bob jones"@domain.com</code>
  38. </para>
  39. <para>
  40. Algunos formatos obsoletos de email actualmente no validan
  41. (por ejemplo los retornos de carro o "\" un caracter en una dirección
  42. de correo electrónico).
  43. </para>
  44. <para>
  45. <emphasis role="strong">Validar diferentes tipos de nombres de host</emphasis>
  46. </para>
  47. <para>
  48. La parte nombre de host de una dirección de correo es validado contra
  49. <link linkend="zend.validate.set.hostname"><code>Zend_Validate_Hostname</code></link>.
  50. Por defecto sólo son aceptados nombres de host DNS de la forma
  51. <code>domain.com</code>, aunque si lo desea también puede aceptar
  52. direcciones IP y nombres de host locales.
  53. </para>
  54. <para>
  55. Para ello necesita instanciar a <code>Zend_Validate_EmailAddress</code>
  56. pasando un parámetro para indicar el tipo de nombres de host que quiere aceptar.
  57. Más detalles están incluidos en <code>Zend_Validate_EmailAddress</code>,
  58. aunque abajo hay un ejemplo de cómo aceptar tanto nombres de host DNS y
  59. locales:
  60. <programlisting role="php"><![CDATA[
  61. $validator = new Zend_Validate_EmailAddress(
  62. Zend_Validate_Hostname::ALLOW_DNS |
  63. Zend_Validate_Hostname::ALLOW_LOCAL);
  64. if ($validator->isValid($email)) {
  65. // email parece ser válido
  66. } else {
  67. // email es inválido; muestre las razones
  68. foreach ($validator->getMessages() as $message) {
  69. echo "$message\n";
  70. }
  71. }
  72. ]]>
  73. </programlisting>
  74. </para>
  75. <para>
  76. <emphasis role="strong">Verificar si el nombre de host realmente acepta email</emphasis>
  77. </para>
  78. <para>
  79. Sólo porque una dirección de correo electrónico está en el formato correcto,
  80. no necesariamente significa que esa dirección de correo electrónico
  81. existe realmente. Para ayudar a resolver este problema, puede usar la
  82. validación MX para comprobar si existe una entrada MX (email) en el
  83. registro DNS para correo electrónico en ese nombre de host.
  84. Esto le dice que el nombre de host acepta email, pero no le dice si la
  85. dirección de correo electrónico exacta es válida en si misma.
  86. </para>
  87. <para>
  88. La comprobación MX no está activada por defecto y en este momento es
  89. soportada sólo por plataformas UNIX.
  90. Para habilitar el control MX puede pasar un segundo parámetro al
  91. constructor <code>Zend_Validate_EmailAddress</code>.
  92. <programlisting role="php"><![CDATA[
  93. $validator = new Zend_Validate_EmailAddress(Zend_Validate_Hostname::ALLOW_DNS,
  94. true);
  95. ]]>
  96. </programlisting>
  97. Alternativamente, para activar o desactivar la validación MX puede pasar
  98. <code>true</code> o <code>false</code> a <code>$validator->setValidateMx()</code>.
  99. </para>
  100. <para>
  101. Al habilitarlo, se usarán las funciones de red para comprobar
  102. la presencia de un registro MX en el nombre de host de la dirección
  103. de correo electrónico que desea validar.
  104. Tenga en cuenta esto probablemente hará más lento su script.
  105. </para>
  106. <para>
  107. <emphasis role="strong">Validating International Domains Names</emphasis>
  108. </para>
  109. <para>
  110. <code>Zend_Validate_EmailAddress</code> también comparará caracteres
  111. internationales que existen en algunos dominios.
  112. Esto se conoce como soporte de International Domain Name (IDN).
  113. Está activado por defecto, aunque puede deshabilitarlo internamente
  114. cambiando el ajuste a través del objeto <code>Zend_Validate_Hostname</code>
  115. que existe en <code>Zend_Validate_EmailAddress</code>.
  116. <programlisting role="php"><![CDATA[
  117. $validator->hostnameValidator->setValidateIdn(false);
  118. ]]>
  119. </programlisting>
  120. Sobre el uso de <code>setValidateIdn()</code> encontrará más información
  121. en la documentación de <code>Zend_Validate_Hostname</code>.
  122. </para>
  123. <para>
  124. Tenga en cuenta que los IDNs se validarán solo si
  125. usted permite que nombres de host DNS sean validados.
  126. </para>
  127. <para>
  128. <emphasis role="strong">Validar Dominios de Nivel Superior (TLD)</emphasis>
  129. </para>
  130. <para>
  131. Por defecto, un nombre de host se cotejará con una lista conocida de TLDs.
  132. Está activado por defecto, aunque puede deshabilitarlo cambiando el
  133. ajuste a través del objeto interno <code>Zend_Validate_Hostname</code>
  134. que existe en <code>Zend_Validate_EmailAddress</code>.
  135. <programlisting role="php"><![CDATA[
  136. $validator->hostnameValidator->setValidateTld(false);
  137. ]]>
  138. </programlisting>
  139. Encontrará más información sobre el uso de <code>setValidateTld()</code>
  140. en la documentación de <code>Zend_Validate_Hostname</code>.
  141. </para>
  142. <para>
  143. Tenga en cuenta que los TLDs se validarán solo si
  144. usted permite que nombres de host DNS sean validados.
  145. </para>
  146. </sect2>
  147. <!--
  148. vim:se ts=4 sw=4 et:
  149. -->