Edición de «Validando formulario con clase kumbia validate»

De KumbiaPHP Framework Wiki

Advertencia: no has iniciado sesión. Tu dirección IP se hará pública si haces cualquier edición. Si inicias sesión o creas una cuenta, tus ediciones se atribuirán a tu nombre de usuario, además de otros beneficios.

Puedes deshacer la edición. Antes de deshacer la edición, comprueba la siguiente comparación para verificar que realmente es lo que quieres hacer, y entonces guarda los cambios para así efectuar la reversión.

Revisión actual Tu texto
Línea 1: Línea 1:
'''Atención: Este tutorial esta basado en la version 1.x de KumbiaPHP Framework.'''
+
Esta practica esta basada en la version 1 Spirit beta2 de KumbiaPHP Framework.  
  
 
Muchas veces necesitamos usar formularios para que una empresa/persona contacte con nosotros a través de nuestra web. Para validar los datos enviados y evitar un mal uso del mismo, el equipo de Kumbia ha desarrollado una nueva clase llamada Validate desvinculada de las validaciones propias de los modelos basados en ActiveRecord.
 
Muchas veces necesitamos usar formularios para que una empresa/persona contacte con nosotros a través de nuestra web. Para validar los datos enviados y evitar un mal uso del mismo, el equipo de Kumbia ha desarrollado una nueva clase llamada Validate desvinculada de las validaciones propias de los modelos basados en ActiveRecord.
  
Para este tutorial necesitaremos como mínimo un controller, un modelo y una vista. Si descargamos el paquete KumbiaPHP del GitHub podemos usar el controller por defecto y su vista y sólo nos quedaría crear el modelo.
+
Para este tutorial necesitaremos como mínimo un controller, un modelo y una vista. Si descargamos el paquete KumbiaPHP del GitHub podemos usar el controller por defecto y su vista.
  
=== Modelo: sendform.php ===
+
'''Modelo: sendform.php'''
  
 
<source lang=php line>
 
<source lang=php line>
 
class SendForm {
 
class SendForm {
 +
 +
private $reglas = array();
 +
private $datos = array();
 
 
private function reglas() {
+
private function __construct($datos) {
 +
 +
$this->datos = $datos;
 +
 +
}
 +
 
 +
private function __reglas() {
 
 
return array(
+
$this->reglas = array(
'NombreCompleto' => [
+
'NombreCompleto' => array(
'required' => ['error' => 'Indique su nombre.'],
+
'required'=>array('error'=>'Rellene su nombre.'),
'alpha'   => ['error' => 'Nombre incompleto o incorrecto.']
+
'alpha' =>array('error'=>'Nombre incompleto o incorrecto.')
],
+
),
'Email' => [
+
'Email' => array(
'required' => ['error' => 'Indique su email.'],
+
'required'=>array('error'=>'Rellene el email.'),
'email'   => ['error' => 'Email incorrecto.']
+
'email' => array('error'=>'Email incorrecto.')
],
+
),
'Movil' => [
+
'Movil' => array(
'required' => ['error' => 'Indique su teléfono / móvil.'],
+
'required'=>array('error'=>'Rellene el teléfono / móvil.'),
'length'   => ['min' => '9',
+
'length' => array('min'=>'9','max'=>'14','error'=>'Teléfono / móvil incorrecto'),
                                'max' => '17',
+
'pattern' => array('regex'=>'[0-9]\+.-\ ', 'error'=>'Teléfono no válido')
                                'error' => 'Teléfono / móvil incorrecto'],
+
),
'pattern' => ['regexp' => '/^\+(?:[0-9] ?){6,14}[0-9]$/',  
+
'Asunto' => array(
                                'error' => 'Teléfono incorrecto. Formato ejemplo. +34 862929929']
+
'required'=>array('error'=>'Indique un asunto.'),
],
+
),
'Asunto' => [
+
'Mensaje' => array(
'required' => ['error' => 'Indique un asunto.'],
+
'required'=>array('error'=>'Indique un mensaje.'),
],
+
'length'=>array('min'=>20, 'error'=>'Si es posible, concrete más en su mensaje.'),
'Mensaje' => [
+
)
'required' => ['error' => 'Indique un mensaje.'],
 
'length'   => ['min' => 100,
 
                                'error' => 'Si es posible, concrete más en su mensaje.'],
 
]
 
 
);
 
);
 +
 +
 +
}
 +
 +
 +
public function mensaje() {
 +
 +
// Contenido del email
 +
$contenido = '<p>Hola,';
 +
$contenido .= '<p>'.$data['NombreCompleto'].' quiere contactar por ';
 +
$contenido .= '<b>'. $data['Asunto'].'</b> y comenta lo siguiente:</p>';
 +
$contenido .= '<p>'.nl2br($data['Mensaje']).'</p>';
 +
$contenido .= '<p><b>Datos de contacto</b></p>';
 +
$contenido .= '<p>Empresa: '.$data['Empresa'];
 +
$contenido .= '<br>Cargo: '.$data['CargoEmpresa'];
 +
$contenido .= '<br>Email: '.$data['Email'];
 +
$contenido .= '<br>Teléfono: '.$data['Movil'].'</p>';
  
 +
return $contenido;
 +
 
}
 
}
  
 +
 +
public function enviar() {
 +
 +
 +
$validador = new Validate($this->datos, $this->obtenerReglas());
 +
if (!$validador->exec()) {
 +
$validador->flash();
 +
} else {
 +
// Enviar Formulario
 +
}
  
    // Envio de datos para generar email
+
}
    public function enviar($datos) {
 
   
 
        $validador = new Validate($datos, $this->reglas() );
 
        if (!$validador->exec()) {
 
                $validador->flash();
 
                return false;
 
        }
 
   
 
        // Enviar email
 
   
 
    }
 
  
 
}
 
}
 
</source>
 
</source>
  
===Vista: index.phtml===
+
'''Vista: index.phtml'''
  
 
En nuestra vista debemos añadir los controles para los campos del formulario. Hemos usado la nomenclatura contactar.<field> para agrupar en una única variable los datos del formulario.
 
En nuestra vista debemos añadir los controles para los campos del formulario. Hemos usado la nomenclatura contactar.<field> para agrupar en una única variable los datos del formulario.
Línea 65: Línea 88:
  
 
<div class="container">
 
<div class="container">
<?= Form::open() ?>
+
<?php echo Form::open() ?>
 +
 
 
<?php View::content() ?>
 
<?php View::content() ?>
 +
 +
 
<fieldset><legend>Contactar</legend>
 
<fieldset><legend>Contactar</legend>
<label required>Nombre completo:
+
<?php echo Form::label('Nombre completo:', 'contactar_NombreCompleto') ?> <?php echo Form::text('contactar.NombreCompleto') ?>
<?= Form::text('contactar.NombreCompleto') ?>
+
<?php echo Form::label('Email:', 'contactar_Email') ?> <?php echo Form::text('contactar.Email') ?>
</label>
+
<?php echo Form::label('Teléfono / Móvil:', 'contactar_Movil') ?> <?php echo Form::text('contactar.Movil') ?>
<label required>Email:
+
<?php echo Form::label('Mensaje:', 'contactar_Mensaje') ?> <?php echo Form::textarea('contactar.Mensaje') ?>
<?= Form::text('contactar.Email') ?>
+
 
</label>
+
<?php echo Form::submit('Enviar') ?>
<label required>Teléfono / Móvil:
 
<?= Form::text('contactar.Movil') ?>
 
</label>
 
<label required>Mensaje:
 
<?= Form::textarea('contactar.Mensaje') ?>
 
</label>
 
<?= Form::submit('Enviar') ?>
 
 
</fieldset>
 
</fieldset>
<?= Form::close() ?>
+
 
 +
<?php echo Form::close() ?>
 +
 
 
</div>
 
</div>
 +
  
 
</source>
 
</source>
  
===Controller: index_controller.php===
+
'''Controller: index.phtml'''
  
 
<source lang=php line>
 
<source lang=php line>
 
 
class IndexController extends AppController
 
{
 
 
    public function index()
 
    {
 
        // Verificamos que se envían datos desde el formulario
 
if (Input::hasPost('contactar')) {
 
 
$form = new SendForm();
 
// Procesamos envio de formulario
 
if ($form->enviar(Input::post('contactar'))) {
 
// Si se envía correctamente, limpiamos el formulario para evitar reenvíos
 
Input::delete('contactar');
 
}
 
 
}
 
 
    }
 
 
}
 
  
  
 
</source>
 
</source>
 
===Notas finales===
 
 
Este tipo de validaciones a nivel de servidor son una excelente herramienta para asegurarnos que los datos llegan correctamente. Validate también se puede combinar con la librería Filter para evitar inyecciones de código o ataques malicioso basados en formularios.
 
  
  
  
[[Categoría:Tutoriales KumbiaPHP]]
+
[ En desarrollo ]

Ten en cuenta que todas las contribuciones a KumbiaPHP Framework Wiki pueden ser editadas, modificadas o eliminadas por otros colaboradores. Si no deseas que las modifiquen sin limitaciones, no las publiques aquí.
Al mismo tiempo, asumimos que eres el autor de lo que escribiste, o lo copiaste de una fuente en el dominio público o con licencia libre (véase Proyecto:Derechos de autor para más detalles). ¡No uses textos con copyright sin permiso!

Para editar esta página, responde la pregunta que aparece abajo (más información):

Cancelar Ayuda de edición (se abre en una ventana nueva)