Introducción a Zend Framework

 Aprendiendo Zend Framework

Apéndice

 Referencia de Zend Framework


  • Zend_Gdata
  • Zend_Http
  • Zend_InfoCard
  • Zend_Json
  • Zend_Layout
  • Zend_Ldap
  • Zend_Loader
  • Zend_Locale
  • Zend_Log
  • Zend_Mail
  • Zend_Markup
  • Zend_Measure
  • Zend_Memory
  • Zend_Mime
  • Zend_Navigation
  • Zend_Oauth
  • Zend_OpenId
  • Zend_Paginator
  • Zend_Pdf
  • Zend_ProgressBar
  • Zend_Queue
  • Zend_Reflection
  • Zend_Registry
  • Zend_Rest

  • Zend_Search_Lucene
  • Zend_Serializer
  • Zend_Server
  • Zend_Service
  • Zend_Session
  • Zend_Soap
  • Zend_Tag
  • Zend_Test
  • Zend_Text
  • Zend_TimeSync
  • Zend_Tool
  • Zend_Tool_Framework
  • Zend_Tool_Project
  • Zend_Translate
  • Zend_Uri
  • Zend_Validate
  • Zend_Version
  • Zend_View
  • Zend_Wildfire
  • Zend_XmlRpc
  • ZendX_Console_Process_Unix
  • ZendX_JQuery
  • Traducción al 26.9% - Actualizado el 2011-11-16 - Revisión 24249 - Versión ZF 1.11.x

    75.3. Cadenas de Validadores

    Frecuentemente deben aplicarse múltiples validaciones a algún valor en un orden particular. El siguiente código demuestra una forma de resolver el ejemplo de la introducción , donde el nombre de usuario debe tener entre 6 y 12 caracteres alfanuméricos.

    // Crea una cadena de validadores y le agrega validadores
    $validatorChain = new Zend_Validate();
    $validatorChain->addValidator(
                        new 
    Zend_Validate_StringLength(array('min' => 6,
                                                             
    'max' => 12)))
                   ->
    addValidator(new Zend_Validate_Alnum());

    // Valida el username
    if ($validatorChain->isValid($username)) {
        
    // username pasó la validación
    } else {
        
    // username falló en la validación; muestre las razones
        
    foreach ($validatorChain->getMessages() as $message) {
            echo 
    "$message\n";
        }
    }

    Los validadores se ejecutan en el orden en que se agregaron a Zend_Validate . En el ejemplo anterior, el nombre de usuario, primero se comprueba que su longitud esté entre 6 y 12 caracteres y luego se controla para garantizar que sólo contiene caracteres alfanuméricos. La segunda validación; de caracteres alfanuméricos; se realiza independientemente de que la primera validación; de longitud entre 6 y 12 caracteres; tenga éxito. Esto significa que si ambas validaciones fallan, getMessages() devolverá mensajes de fracaso desde ambos validadores.

    En algunos casos tiene sentido detener la cadena de validación si falla alguno de los procesos de validación. Zend_Validate acepta tales casos pasando como segundo parámetro el método addValidator() . Poniendo $breakChainOnFailure a TRUE , el validador agregado quebrará la cadena de ejecución por el fracaso, que evita correr cualquier otra validación que se decida que es innecesaria o inapropiada para la situación. Si el ejemplo anterior fue escrito como sigue, entonces el sistema de validación alfanumérica no se ejecutará si falla la longitud del string de validación:

    $validatorChain->addValidator(
                        new 
    Zend_Validate_StringLength(array('min' => 6,
                                                             
    'max' => 12)),
                        
    true)
                   ->
    addValidator(new Zend_Validate_Alnum());

    Cualquier objeto que implemente Zend_Validate_Interface puede ser utilizado en una cadena de validación.

    digg delicious meneame google twitter technorati facebook

    Comentarios

    Loading...