IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

Page de contact


Sujet :

Langage PHP

  1. #1
    Candidat au Club
    Homme Profil pro
    Infographiste
    Inscrit en
    Novembre 2011
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vosges (Lorraine)

    Informations professionnelles :
    Activité : Infographiste
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Novembre 2011
    Messages : 9
    Points : 4
    Points
    4
    Par défaut Page de contact
    Bonsoir,
    Je suis sur la "fabrication" d'un site de e-commerce et je bloque sur certainement une super bêtise…

    Voilà le code PHP de ma page entière qui s'appel contact.php. Pour info à chaque tentative d'envoi du formulaire les informations arrivent bien dans la base de donnée "contact" mais le mail ne part pas et l'erreur affichée est celle là :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $_SESSION['erreur'] = "Un problème est survenu lors de la sauvegarde. Envoyer un mail à anthony@europub.fr afin de nous prévenir de tout dysfonctionnement";


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    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
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    <?php include 'INC/includes.php';
     
    if($_SERVER['REQUEST_METHOD'] == "POST"){
        $validate =true;
     
        // verification du nom
        if(empty($_POST['nom'])){
            $erreur_nom = "Indiquer votre nom.";
        $validate = false;
        }
     
        // verification du prenom
        if(empty($_POST['prenom'])){
            $erreur_prenom = "Indiquer votre prénom.";
        $validate = false;
        }
     
        // verification du email
        if(empty($_POST['email'])){
            $erreur_email = "Indiquer votre email.";
        $validate = false;
        }
        if(!empty($_POST['email']) && !(filter_var($_POST['email'],FILTER_VALIDATE_EMAIL))){
            $erreur_email = "Indiquer une adresse mail valide.";
        $validate = false;
        }
     
        // verification du telephone
        if(empty($_POST['telephone'])){
            $erreur_telephone = "Indiquer votre t&eacute;l&eacute;phone.";
        $validate = false;
        }
     
        // verification du sujet
        if(empty($_POST['sujet'])){
            $erreur_sujet = "Indiquer un sujet.";
        $validate = false;
        }
     
        // verification du message
        if(empty($_POST['message'])){
            $erreur_message = "Veuillez indiquer votre demande.";
        $validate = false;
        }
     
        if($validate){
     
        $data = array(
            'nom'=>htmlspecialchars($_POST['nom']),
            'prenom' =>htmlspecialchars($_POST['prenom']),
            'email' =>htmlspecialchars($_POST['email']),
            'telephone' =>htmlspecialchars($_POST['telephone']),
            'sujet' =>htmlspecialchars($_POST['sujet']),
            'message' =>htmlspecialchars($_POST['message']),
        );
     
            $req= $DB->insert('INSERT INTO contact (nom,prenom,email,telephone,sujet,message) VALUES (:nom,:prenom,:email,:telephone,:sujet,:message)' ,$data);
            if($rep){
     
     
            $to= 'meunier_anthony@me.com';
            $ubject = ($sujet);
            $message .= 'Nom:' .$nom."\r\n";
            $message .= 'Pr&eacute;nom:' .$prenom."\r\n";
            $message = nl2br($message);
            $headers = 'From:' .$email."\r\n";
            $headers .= 'MIME-version: 1.0'."\r\n";
            $headers .= 'Content-type: text/html; charset=utf-8'."\r\n";
     
     
            if(mail($to,$subject,$message,$headers)){
                $_SESSION['message'] = "Un email à été envoyé a votre messagerie avec des instructions pour activer votre compte.";
                unset($_POST);
            }else{
                $_SESSION['erreur'] = "Un problème est survenu lors de l'envoi de votre email.";
     
                }
        }else{
            $_SESSION['erreur'] = "Un problème est survenu lors de la sauvegarde. Envoyer un mail à anthony@europub.fr afin de nous prévenir de tout disfonctionnement.";
        }
    }
     
     
    }
     
     include 'INC/header.php';
     include 'INC/panel.php'; ?>
     
     
     <!-- PAGE -->
    <div id="form_signup" class="fond_signup">
        <div id ="contenuPage" class="container clearfix">  
            <!-- <div id="content"> -->
     
     
                <form action="contact.php" id="contact" class="contact clearfix" method="POST">
     
                    <h1 class="font">Nous contacter</h1></br>
     
                        <div class="single">  
                        <!--  message de la session -->
                        <?php if (isset($_SESSION['message'])): ?>
                            <div class="success"><?php echo $_SESSION['message']; ?></div>
                        <?php unset($_SESSION['message']); ?>
                        <?php endif ?>
     
                        <?php if (isset($_SESSION['erreur'])): ?>
                            <div class="alert_error"><?php echo $_SESSION['erreur']; ?></div>
                        <?php unset($_SESSION['erreur']); ?>
                        <?php endif ?>
                        </div>
     
                            <p>
                                <label for="nom">Nom :&nbsp;&nbsp;</label>
                                <input class="input" type="text" name="nom" placeholder="Votre nom">
                            <?php if(!empty($erreur_nom)) :?>
                                <span class="error"> <?php echo $erreur_nom; ?></span>
                            <?php endif ?>
                            </p>
     
                            <p>
                                <label for="prenom">Prenom :&nbsp;&nbsp;</label>
                                <input class="input" type="text" name="prenom" placeholder="Votre prenom">
                            <?php if(!empty($erreur_prenom)) :?>
                                <span class="error"> <?php echo $erreur_prenom; ?></span>
                            <?php endif ?>
                            </p>
     
                            <p>
                                <label for="email">Email :&nbsp;&nbsp;</label>
                                <input class="input" type="text" name="email" placeholder="email@nomdedomaine.com">
                            <?php if(!empty($erreur_email)) :?>
                                <span class="error"> <?php echo $erreur_email; ?></span>
                            <?php endif ?>
                            </p>
     
                            <p>
                                <label for="telephone">T&eacute;l&eacute;phone :&nbsp;&nbsp;</label>
                                <input class="input" type="text" name="telephone" placeholder="Votre t&eacute;l&eacute;phone">
                            <?php if(!empty($erreur_telephone)) :?>
                                <span class="error"> <?php echo $erreur_telephone; ?></span>
                            <?php endif ?>
                            </p>
     
                            <p>
                                <label for="sujet">Sujet :&nbsp;&nbsp;</label>
                                <input class="input" type="text" name="sujet" placeholder="Sujet">
                            <?php if(!empty($erreur_sujet)) :?>
                                <span class="error"> <?php echo $erreur_sujet; ?></span>
                            <?php endif ?>
                            </p>
     
                            <p>
                                <label for="message">Votre message :&nbsp;&nbsp;</label>
                                <textarea name="message" class="msg" rows="7" cols="60" placeholder="Votre message ici..."></textarea>
                            <?php if(!empty($erreur_message)) :?>
                                <span class="error"> <?php echo $erreur_message; ?></span>
                            <?php endif ?>
                            </p>
     
                            <p>
                                <input type="submit" class="submit_signup" value="Envoyer">
                            </p>
                </form>
     
     
     
     
     
        </div> <!-- contenuPage -->
    </div> <!-- #page -->
     
     
     
    <?php include 'INC/footer.php'; ?>
    Merci d'avance pour votre aide et surtout bonne soirée.
    Anthony

  2. #2
    Membre expérimenté
    Homme Profil pro
    Développeur C++
    Inscrit en
    Avril 2012
    Messages
    771
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur C++
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2012
    Messages : 771
    Points : 1 631
    Points
    1 631
    Par défaut
    Bonsoir,

    la méthode insert de la classe DB renvoi t'elle bien un Booléen ?

  3. #3
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 831
    Points
    5 831
    Billets dans le blog
    1
    Par défaut
    Bonsoir,

    as-tu testé ta requête dans PHPMyAdmin et peux-tu donner INC/includes.php doit contenir la définition de la classe ?

  4. #4
    Candidat au Club
    Homme Profil pro
    Infographiste
    Inscrit en
    Novembre 2011
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vosges (Lorraine)

    Informations professionnelles :
    Activité : Infographiste
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Novembre 2011
    Messages : 9
    Points : 4
    Points
    4
    Par défaut
    Oui tout à fait, en fait je suis perdu dans tout ce que j'ai fait voici le includes.php

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    <?php session_start();
    include 'config.php';
    include 'classes/Db.php';
    require 'classes/panier.php';
    require 'classes/auth.php';
    $DB = new DB();
    $panier = new Panier($DB);
     
     
    include 'classes/Texte.php';
    include 'classes/User.php';
     
    // cacher les erreurs pour la production
    ini_set('error_reporting', 0);
    // afficher les erreurs lors du developpement 
    //ini_set('error_reporting', E_ALL);
     
    ?>

    Puis le fichier Db.php


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    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
    <?php 
    class Db {
     
    	private $host = HOST;
    	private $name = DBNAME;
    	private $user =USER;
    	private $pass= PWD;
     
    	public $connexion;
     
    	function __construct($host=null,$name=null,$user=null,$pass=null){
     
    		if($host != null){
     
    			$this->host = $host;
    			$this->dbname = $dbname;
    			$this->user = $user;
    			$this->pass = $pass;
    		}
     
    		try{
     
    			$this->connexion = new PDO('mysql:host='.$this->host.';dbname='.$this->name,$this->user, $this->pass,array(
    					PDO::MYSQL_ATTR_INIT_COMMAND =>'SET NAMES UTF8',
    					PDO::ATTR_ERRMODE => PDO::ERRMODE_WARNING
    				));
     
    		}catch(PDOException $e){
    			echo "Erreur : Impossible de se connecter à la base de données.";
    			die();
    		}
     
    	}
     
     
    	public function query($sql,$data=array()){
    		$req = $this->connexion->prepare($sql);
    		$req->execute($data);
     
    		return $req->fetchAll(PDO::FETCH_OBJ);
    	}
     
    	public function tquery($sql,$data=array()){
    		$req = $this->connexion->prepare($sql);
    		$req->execute($data);
     
    		return $req->fetchAll(PDO::FETCH_ASSOC);
    	}
     
    	public function insert($sql,$data=array()){
    		$req = $this->connexion->prepare($sql);
    		$nbr = $req->execute($data);
    		return $nbr;
    	}
     
    }
     
     ?>
    Merci davance.

    PS pour info j'ai déjà créer un système de session utilisateur avec connexion et après la page de contact je passerais au panier et au paiement si j'y arrive quoi :/

  5. #5
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 831
    Points
    5 831
    Billets dans le blog
    1
    Par défaut
    Je suis loin d'être un expert de la POO mais il me semble que la classe DB devrait hériter de PDO...

  6. #6
    Candidat au Club
    Homme Profil pro
    Infographiste
    Inscrit en
    Novembre 2011
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vosges (Lorraine)

    Informations professionnelles :
    Activité : Infographiste
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Novembre 2011
    Messages : 9
    Points : 4
    Points
    4
    Par défaut
    Et bien pour tout avouer je ne suis pas expert non plus voir même un grand débutant et je ne suis pas sur de comprendre ce que tu dit…

    Je suis désolé de ne pas comprendre, je ne vois pas en fait ce qu'il faudrait ajouter ou modifier pour que ça marche.

  7. #7
    Membre émérite
    Avatar de gene69
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    1 769
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Janvier 2006
    Messages : 1 769
    Points : 2 446
    Points
    2 446
    Par défaut
    non t'inquiete tu composes PDO au lieu d'heriter, ça te fait plus de travail pour transporter les fonctionnalités de pdo vers ta classe maison mais ça te simplifie la vie à l'écriture.

    On probleme c'est ton message d'erreur. Tu ne valides pas les données reçues et c'est le sens de ton message d'erreur... sauf que ton message d'erreur laisse sous entendre qu'il est tombé une bombe nucléaire sur le serveur.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    //ajoute
    if (isset($erreur_nom)){
    $_SESSION['erreur'] = $erreur_nom .' '.$_SESSION['erreur'];
    }

  8. #8
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 831
    Points
    5 831
    Billets dans le blog
    1
    Par défaut
    J'ai suivi sur la POO en PHP une formation en décembre (boulot=webmaster, donc facile de se faire payer des formations ), et voilà comment faire hériter : class DB extends PDO {etc.} (et PDO est une classe PHP donc pas besoin de la mettre sur le serveur).
    Mais si tu ne t'y connais pas, le code ne doit pas être de toi...

    Gene69, au cours de ma formation, on faisait ainsi hériter une classe de PDO et rien d'autre à faire de plus.

  9. #9
    Membre émérite
    Avatar de gene69
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    1 769
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Janvier 2006
    Messages : 1 769
    Points : 2 446
    Points
    2 446
    Par défaut
    oui si tu veux tu peux hériter. Dans le temps ou il n'y avait pas PDO, on créait un objet indépendant avec des methodes (abtraites à partir de php5 ) et on dérivait cet objet pour avoir une déclinaison Mysql, MsSQL, Obdc, Oracle et on avait ainsi une interface régulière quelque soit la base. On instanciait la classe fille et on la manipulait comme la classe mere. C'était l'ancien temps. Les objets de la classe fille "composait" la ressource de la base de donnée avec les fonctions du pilote.

    Tu n'es même pas obligé de dériver la classe PDO. Mais parfois c'est pratique de pouvoir surcharger la méthode prépare() pour ajouter un écho du sql passé en argument avant d'appeler super::prepare()

    c'est beau ça d'avoir des formations php...

  10. #10
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 831
    Points
    5 831
    Billets dans le blog
    1
    Par défaut
    c'est beau ça d'avoir des formations php...
    J'en suis à 3 en PHP (dont 2 fois PHP POO car suite à la première, j'ai réalisé que j'avais oublié (mais la 2e super car en plus, j'ai appris le MVC (model/view/controller)...) et une sur Zend (et avant une sur le javascript...)

  11. #11
    Candidat au Club
    Homme Profil pro
    Infographiste
    Inscrit en
    Novembre 2011
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vosges (Lorraine)

    Informations professionnelles :
    Activité : Infographiste
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Novembre 2011
    Messages : 9
    Points : 4
    Points
    4
    Par défaut
    Oui tout à fait, je ne m'y connais que très peut en fait je suis en train d'apprendre heures après heures. J'ai acheté un bouquin avec un peut de motivation et surtout des aller et retour sur des sites internet.

    Je suis donc un super débutant.
    J'ai réussi à faire envoyer le mail en enlevant la partie de l'intégration des éléments $_POST dans la table 'contact'.

    Dès que j'essai d'envoyer les données, le mail ne part pas mais les données arrive bien dans la table 'contact'.

    J'aurais la possibilité d'effectuer une première formation par mon boulot aussi en fin d'année mais en regardant ça me fait peur car toute les formations sont données comme pré-requis "les bases du PHP". Ok mais finalement qu'est ce que les bases ?
    Car si c'est pour passer une formation à ne rien comprendre… ça ne va pas être très instructif même si c'est une bonne formation.

  12. #12
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 831
    Points
    5 831
    Billets dans le blog
    1
    Par défaut
    Pour acquérir les bases, il faut te palucher un tuto : http://sylvie-vauthier.developpez.co...rand-debutant/.
    Moi, pour apprendre le PHP, je m'étais paluché un bouquin (mais c'est vrai que je partais pas de 0 : une dizaine d'années de codage en langage C...)

Discussions similaires

  1. Page de contact
    Par rorog2 dans le forum Langage
    Réponses: 7
    Dernier message: 06/06/2015, 18h43
  2. Page de contact
    Par artemiz dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 3
    Dernier message: 05/07/2013, 17h28
  3. [eZ Publish] Page de contact - How to ?
    Par zouberi dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 5
    Dernier message: 21/07/2011, 10h25
  4. Réponses: 3
    Dernier message: 25/06/2007, 16h50

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo