Utilisateur anonyme
-
Modifié par onmyown31 le 12/04/2011 à 14:37
le père -
4 avril 2011 à 18:20
Bonjour,
Voilà j'ai un petit soucis concernant la réalisation d'un formulaire de contact en html/php.
J'ai voulu me débrouiller tt seule en bricolant par-ci par-là des morceaux de codes, sauf que résultat > ça marche à moitié !
J'ai une page de contact tt simple en html (et sa feuille csss) et une page en php...J'ai transféré tt ça sur mon site. Le truc est que les information sont bien envoyées sur ma boite mail mais ma page php ne rétablit pas la liaison avec le site en redirigeant vers une page html de confirmation d'envoi (merci.html). Si quelqu'un a une idée, ça serait vraiment bienvenu !
Voilà le code que j'ai utilisé :
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>contact</title>
</head>
<body>
</body>
<?php
// On vérifie si la fonction ini_set() a été désactivée...
$desactive = ini_get('disable_functions');
if (preg_match("/ini_set/i", "$desactive") == 0) {
// Si elle n'est pas désactivée, on définit ini_set de manière à n'afficher que les erreurs...
ini_set("error_reporting" , "E_ALL & ~E_NOTICE");
}
// Vérifier que le formulaire a été envoyé...
if (isset($_POST['envoi'])) {
//On commence une session pour enregistrer les variables du formulaire...
session_start();
$_SESSION['zone_email1'] = $_POST['zone_email1'];
//Enregistrement des paramètres de la case 1...
$_SESSION['case1_'][0] = "";
if (isset($_POST['case1_'][0])) {
$_SESSION['case1_'][0] = $_POST['case1_'][0];
} // Fin du if...
$_SESSION['case1_'][1] = "";
if (isset($_POST['case1_'][1])) {
$_SESSION['case1_'][1] = $_POST['case1_'][1];
} // Fin du if...
$_SESSION['case1_'][2] = "";
if (isset($_POST['case1_'][2])) {
$_SESSION['case1_'][2] = $_POST['case1_'][2];
} // Fin du if...
//Enregistrement des zones de texte...
$_SESSION['zone_texte1'] = $_POST['zone_texte1'];
// Définir l\'icone apparaissant en cas d\'erreur...
// Définir sur 0 pour afficher un petit x de couleur rouge.
// Définir sur 1 pour afficher l\'image d\'une croix rouge telle que celle utilisée dans l\'assistant
// Si vous utilisez l\'option 1, l\'image de la croix rouge \'icone.gif\' doit se trouver dans le répertoire \'images\',
// ce dernier devant se trouver au même niveau que votre formulaire...
$flag_icone = 0;
// On vérifie si $flag_icone est défini sur 0 ou 1...
if ($flag_icone == 0) {
$icone = "<b><font size=\"3\" face=\"Arial, Verdana, Helvetica, sans-serif\" color=\"#CC0000\">x</font></b>";
} else {
$icone = "<img src=\"images/icone.gif\"";
}
// Définir l'indicateur d'erreur sur zéro...
$flag_erreur = 0;
// N'envoyer le formulaire que s'il n'y a pas d'erreurs...
if ($flag_erreur == 0) {
// Send the e-mail
if (@!mail($email_dest,$sujet,$sortie,$entetes)) {
echo("Envoi du formulaire impossible");
exit();
} else {
// Rediriger vers la page de remerciement
header("http://wwwxxx/xxx.html");
exit("");
} // Fin else
} // Fin du if ($flag_erreur == 0) {
} // Fin de if POST
?>
</html>
Tu utilises session_start() et header() après avoir commencé l'envoi des données au client (l'envoi des données a commencé dès le DOCTYPE).
Or ces fonctions utilisent les en-têtes HTTP et doivent donc être utilisées AVANT tout envoi de données.
Il faut que tu réorganises ton code pour respecter cette condition.
Merci de votre réponse ! Donc d'après vous ce n'est qu'une question d'organisation, mais après toutes les infos y sont ? car ce qui est étrange c'est que le formulaire fonctionne...Il ne me redirige simplement pas vers ma page merci.html une fois la demande envoyée...
Je ne sais pas vraiment comment réorganiser mon code du coup.
Il ne faut rien envoyer sur la sortie (même pas un espace ou une ligne vide avant le premier <?php) avant d'avoir exécuté la dernière instruction qui fait appel aux en-têtes - ici c'est ton "header". Ce n'est pas difficile, il suffit par exemple de mettre dans une variable tout ce que tu avais envie d'envoyer avant ($variable.= $truc; au lieu de echo $truc;), et d'attendre d'avoir le droit pour faire l'envoi.
D'ailleurs, je m'aperçois que ton header est mal écrit : tu as mis
header("http://www.monsite/merci.html");
alors que c'est
header("Location: http://www.monsite/merci.html");
qu'il vaut mieux faire suivre de exit(); sinon ton script va continuer de s'exécuter alors que le client l'ignorera.