Formulario WEB sin base de datos: Funcion mail()

Buenos días gente,

Hoy les traigo un ejemplo de código para crear un formulario WEB para enviar correos a tu cuenta personal usando la función mail()

Contexto:

Enviar correos desde una pagina web puede resultar algo muy útil sin tener que complicarte creando bases de datos y direccionarlo a tu correo personal de cualquier dominio.

Estructura:

bool mail ( string $to , string $subject , string $message [, string $additional_headers [, string $additional_parameters ]] )

Parametros:

  • to

Destinatario/s del correo.

El formato de este string debe cumplir con la » RFC 2822. Algunos ejemplos son:

  1. usuario@example.com
  2. usuario@example.com, otrousuario@example.com
  3. Usuario <usuario@example.com>
  4. Usuario <usuario@example.com>, Otro usuario <otrousuario@example.com>
    • Subject:

Título del correo electrónico a enviar.

Precaución

El título debe cumplir con la » RFC 2047.

  • Message:

Mensaje a enviar.

Cada línea debería separarse con un CRLF (\r\n). Las líneas no deberían ocupar más de 70 caracteres.

Precaución

(Sólo en Windows) Cuando PHP se comunica directamente con un servidor SMTP, si encuentra un punto al principio de la línea, éste se elimina. Para evitar esto es necesario reemplazar estas apariciones con un doble punto.

<?php
 $texto = str_replace("\n.", "\n..", $texto);
 ?>
      • Addicional headers (opcional):

String a insertar al final de la cabecera del correo.

Se usa normalmente para añadir cabeceras extra (From, Cc y Bcc). Las cabeceras múltiples adicionales deberían separarse con un CRLF(\r\n). Si se usan datos externos para componer esta cabecera, los datos deberían ser saneados para que no se inyecten cabeceras no deseadas.

Nota:

additional_headers no posee protección de inyección de cabeceras de correo. Por tanto, los usuarios deben asegurarse de que las cabeceras especificadas son seguras y contienen solamente cabeceras. Es decir, nunca iniciar el cuerpo del correo con varias nuevas líneas.
Nota:

Cuando se envía un correo, este debe contener una cabecera From. Puede establecerse con el parámetro additional_headers, o puede definirse un valor predeterminaro en php.ini.

Si no se realiza esta acción se obtendrá un mensaje de error similar a Warning: mail(): "sendmail_from" not set in php.ini or custom "From:" header missing (Advertencia: mail(): "sendmail_from" no establecido en php.ini o falta la cabecera personalizada "From:"). La cabecera From también establece Return-Pathbajo Windows.
Nota:

Si no se reciben los mensajes enviados, intente usar solamente LF (\n). Algunos agentes de transferencia de correo de Unix (como » qmail) reemplzan LF por CRLF automáticamente (lo que conlleva doblar CR si se usa CRLF). Esto debería ser el último recurso, pues no cumple con la » RFC 2822.

 

  • Addicional parameters (opcional):

El parámetro additional_parameters puede usarse para indicar opciones adicionales como opciones de línea de comandos al programa que está configurado para usarse cuando se envía correo, definido por la opción de configuración sendmail_path. Por ejemplo, puede usarse para establecer la dirección de correo del remitente usando sendmail con su opción -f.

Este parámetro es escapado internamente por escapeshellcmd() para prevenir la ejecución del comando. Aunque escapeshellcmd() evita la ejecución del comando, permite añadir parámetros adicionales. Por razones de seguridad, se recomienda que el usuario sanee este parámetro para evitar que se añadan parámetros indeseados al comando.

Ya que escapeshellcmd() se aplica automáticamente, algunos caracteres que están permitidos como direcciones de correo electrónico por algún RFC no se pueden usar. mail() no puede permitir tales caracteres, por lo que en programas donde el uso de tales caracters sea necesario, se recomienda una vía alternativa de enviar correos (como usar un marco de trabajo o una biblioteca).

El usuario usado por el servidor web debería ser añadido como usuario de confianza en la configuración de sendmail para evitar que se añada la cabecera ‘X-Warning’ al mensaje cuando se añada la dirección de remitente (-f) usando este método. Para los usuarios de sendmail, este fichero es /etc/mail/trusted-users.

  • Valores devueltos:

Devuelve TRUE si el correo ha sido aceptado para su envío, de lo contrario FALSE.

Es importante tener en cuenta que si el correo es aceptado para su envío, NO quiere decir que el correo haya alcanzado el destino indicado.

EJEMPLO:

Esté código es el que siempre uso en mis formularios me funciona muy bien

Ver formulario php

<?php

//Captura de datos del formulario
 $vnmb=$_POST['nombre']; 
 $vast=$_POST['asunto'];
 $vdrc=$_POST['direccion'];
 $vtlf=$_POST['telefono'];
 $vmsj=$_POST['mensaje'];
 $vcrr=$_POST['correo'];

// captura de fecha automatica 
 $fecha = time();
 $ff = date("j/n/Y", $fecha);
 $para ='marketing@asescreativestudio.com'. ', '; 
 $para .= 'jekariva@gmail.com';
 
// contenido del mensaje a enviado
 $mensaje = '
 <html>
 <head>
 <title>Formulario de contacto - ASES Creative Studio</title>
 </head>
 <body>
 <p> Ha recibido un mensaje a traves de su página WEB</p>
 <table>
 <tr>
 <th>Nombre: </th><td>'. $vnmb .'</tdh>
 </tr>
 <tr>
 <th>Asunto: </th><td>' . $vast .'</tdh>
 </tr>
 <tr>
 <th>Dirección: </th><td>' . $vdrc .'</tdh>
 </tr>
 <tr>
 <th>Teléfono: </th><td>' . $vtlf .'</tdh>
 </tr>
 <tr>
 <th>Correo: </th><td>' . $vcrr .'</tdh>
 </tr>
 <tr>
 <th>Mensaje: </th><td>'. $vmsj .'</tdh>
 </tr>
 </table>
 </body>
 </html>
 ';
 
// Convierte el html creado como mensaje en una variable
 $mensaje = wordwrap($mensaje, 70, "\r\n");
 
 // Para enviar un correo HTML, debe establecerse la cabecera Content-type
 $cabeceras = 'MIME-Version: 1.0' . "\r\n";
 $cabeceras .= 'Content-type: text/html; charset=iso-8859-1' . "\r\n";

 // Cabeceras adicionales - correo del que aparentemente se esta recibiendo el mensaje

 $cabeceras .= 'From: contacto@asescreativestudio.com ' . "\r\n";

  
 // funcion mail envía el mensaje
 mail( $para, $vast, $mensaje, $cabeceras);
 
 // Mensaje de respuesta
 echo "<html><head><title>ASES Contact</title></head><body><h1> Gracias por contactarnos<br> Pronto nos comunicaremos...</h1></body></html>";
?>

bueno eso es todo, espero les sea útil… si les gustó mi aporte por favor dale me gusta a nuestra página excelente resto de día para todos.

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *