Formulaire JS + Ajax + PHP + e-MAIL

  Information

Tout les thèmes de formulaires sont aujourd'hui vendu en ajax, donc pas de rechargement de page, mais il n'existe pas de source disponible adapté. Nous allons corrigé ce problème.

Merci a Stéphane aka Spout de Webrankinfo.com pour son code source.

Ce code fonctionne, et si il ne fonctionne pas de votre coté, regardez du coté des fichiers externes appelés et vérifier qu'ils sont tous bien en ligne.
  code source classé dans  Formulaires

 
 01    
 02    
 03    
 04    
 05    
 06    
 07    
 08    
 09    
 10    
 11    
 12    
 13    
 14    
 15    
 16    
 17    
 18    
 19    
 20    
 21    
 22    
 23    
 24    
 25    
 26    
 27    
 28    
 29    
 30    
 31    
 32    
 33    
 34    
 35    
 36    
 37    
 38    
 39    
 40    
 41    
 42    
 43    
 44    
 45    
 46    
 47    
 48    
 49    
 50    
 51    
 52    
 53    
 54    
 55    
 56    
 57    
 58    
 59    
 60    
 61    
 62    
 63    
 64    
 65    
 66    
 67    
 68    
 69    
 70    
 71    
 72    
 73    
 74    
 75    
 76    
 77    
 78    
 79    
 80    
 81    
 82    
 83    
 84    
 85    
 86    
 87    
 88    
 89    
 90    
 91    
 92    
 93    
 94    
 95    
 96    
                               
/*---------------------------------------------------------------*/
/*
Titre : Formulaire JS + Ajax + PHP + e-MAIL

URL : https://phpsources.net/code_s.php?id=1075
Auteur : KOogar
Date édition : 28 Juin 2019
Date mise a jour : 13 Aout 2019

Rapport de la maj:
- fonctionnement du code vérifié
*/
/*---------------------------------------------------------------*/

if (!empty($_POST) && !empty($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower(
$_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest') {
if (mail('koog@ar.com', 'New message', $_POST['message'])) {
echo "Message envoyé avec succès.";
} else {
http_response_code(500);
}
exit();
}
?>

<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1,
shrink-to-fit=no">
<link rel="stylesheet"
href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css"
integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZ
w1T" crossorigin="anonymous">
<title>Contact</title>
</head>
<body>
<div class="container">
<form id="contact-form" action="<?php echo $_SERVER['REQUEST_URI']; ?>">
<div class="form-group">
<label for="firstname">Firstname</label>
<input type="text" id="firstname" name="firstname"
class="form-control" required>
</div>
<div class="form-group">
<label for="lastname">Lastname</label>
<input type="text" id="lastname" name="lastname"
class="form-control" required>
</div>
<div class="form-group">
<label for="message">Message</label>
<textarea id="message" name="message" class="form-control"
required></textarea>
</div>

<button type="submit" id="submit" class="btn
btn-primary">Submit</button>
</form>
</div>

<script src="https://code.jquery.com/jquery-3.4.1.min.js"
crossorigin="anonymous"></script>
<script
src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js"
integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz
0W1" crossorigin="anonymous"></script>
<script
src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"
integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07
jRM" crossorigin="anonymous"></script>

<script>
$(function () {
$('#submit').on('click', function (e) {
e.preventDefault();
let $form = $('#contact-form');

if ($form.get(0).checkValidity()) {
$.post($form.attr('action'),
$form.serializeArray()).done(function (data) {
$form.prepend(`<div class="alert
alert-success">${data}</div>`);
}).fail(function(jqXHR, textStatus, errorThrown) {
$form.prepend(`<div class="alert alert-danger">Une
erreur est survenue.</div>`)
});
} else {
$form.get(0).reportValidity();
}
});
});
</script>
</body>
</html>

      Fonctions du code - Doc officielle PHP

Détail    php.net  
Description
Versions PHP
   echo
Affiche une chaîne de caractères
PHP 4, 5, 7 et 8
   empty
Détermine si une variable contient une valeur non nulle
PHP 4, 5, 7 et 8
   exit
Affiche un message et termine le script courant
PHP 4, 5, 7 et 8
   http_response_code
Récupère ou change le code de la réponse HTTP
PHP 4, 5, 7 et 8
   mail
Envoi un mail
PHP 4, 5, 7 et 8
   strtolower
Renvoie une chaîne en minuscules
PHP 4, 5, 7 et 8

   Dites merci aux auteurs pour leurs travail, ça ne coûte rien et ça fait toujours plaisir wink

 Autres snippets qui pourraient vous intéressez

Formulaire complet d'envoi de mail

Compatibilité : PHP 5, PHP 7, PHP 8

Le formulaire est complet. Coller le code sur une page et lancer le script. Attention a mettre votre adresse email avant dans le code source.

Validation d'une adresse mail

Compatibilité : PHP 5, PHP 7, PHP 8

Voici 2 manières de filtrer une adresse email afin de savoir si la syntaxe de l'adresse email est valide ou invalide. Avec la fonction filter_var () ou un regex.

Envoyer un mail type MINE en HTML - PHP Sources

Compatibilité : PHP 5, PHP 7, PHP 8

L'une des taches les plus communes pour un programmeur PHP est qu'il doit faire face au développement d'applications qui envoient des mails MIME.

Découper une adresse e-mail en plusieurs parties

Compatibilité : PHP 5, PHP 7, PHP 8

Fonction qui découpe 1 adresse de courriel en login + nom de domaine. La fonction retourne un tableau associatif des valeurs.

Adresse e-mail/mailto anti-spam (utilisant Javascript)

Compatibilité : PHP 5, PHP 7, PHP 8

Ce script vous permet de crée des liens mailto indéchiffrable par les robots alors que les réels utilisateurs verront votre adresse.

* Requêtes exécutées avec Recherche Contextuelle
avatar

KOogar

  28 Juin 2019

  SOURCE   Télécharger

Information sur les mises à jour

Dernière mise à jour :

    13 Aout 2019
    fonctionnement du code vérifié

6 722 Vues
Compatibilité du code
PHP 5, 7 et 8+