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

PHP & Base de données Discussion :

Connexion Base avec Post


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    899
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 899
    Par défaut Connexion Base avec Post
    Bonsoir,
    J'ai créé un formulaire PHP qui me permet de saisir diverses infos et de les rentrer dans une base MYSQL.
    J'ai créé 2 fichiers PHP :
    enquete.php le plus important le formulaire de saisi s'y trouve.
    upload.php contenant diverses fonctions pour ce travail.
    Voiçi une partie du code d'enquete.php :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <form  action="<?php echo $this->baseurl ?>/dossier/sous_dossier/site_web/Enquete_upload.php" method="post" enctype="multipart/form-data" name="form" id="form" >
    puis
    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
          <input type="submit" name="enregistre"  value="Enregistrer">
         
        </p>
    </form>
    
           
       <?php   
         if (isset ($_POST['enregistre']))
              {
               //   echo"ok enregistre1";
                  
                 
                //On récupère les valeurs entrées par l'utilisateur :
                $etab=$_POST['etablissement'];
                $vers=$_POST['enq_version'];
                $serv=$_POST['direction_service'];
                $comm=$_POST['commentaire'];
                connectMaBase();
         $sql = 'INSERT INTO tenq VALUES("","'.$etab.'","2013","'.$vers.'","'.$serv.'","2012/11/11","'.$comm.'")';     
       
         mysql_query ($sql) or die ('Erreur SQL !'.$sql.'<br />'.mysql_error()); 
                                
                // on ferme la connexion
                mysql_close(); 
               }
                   else 
               {
                 echo"non ok enr";
               } 
            ?>
    le code de upload.php
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    <?php
    function connectMaBase(){
        $base = mysql_connect ('localhost', 'root', '');  
        mysql_select_db ('MaBase', $base) ;
    }
    ?>
    Mon problème est que curieusement quand il teste mon post :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    if (isset ($_POST['enregistre']))
    il va bien dans la condition vrai mais ne tiens pas compte de l'appel à la fonction "connectMaBase()" car si je lui colle une erreur express "ConnectMaBase2" il ne réagit pas.
    J'ai simplifié la description du formulaire mais ça n'y change rien !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <form name="form" method="post" action="<?php echo $this->baseurl ?>/enquete/site_web/enquete_upload.php">
    Là je vois vraiment pas si quelqu'un peut m'aider merçi
    A +

  2. #2
    Membre Expert Avatar de Fench
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Mai 2002
    Messages
    2 353
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Groenland

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 353
    Par défaut
    Bonjour,

    Trois petites choses:
    - Pour ma part, j'éviterais de faire un name et un id ='form' car c aussi le nom de la balise, juste pour un soucis de clareté (mais celà ne doit pas changer grand chose )

    - Ton formulaire fait un post vers 'Enquete_upload.php' alors tu donnes le code de 'enquete.php', mais je pense que celà doit être une erreur qui ne doit pas changer grand chose aussi .

    - Dernier, le truc bête, tu as inclus le fichier 'upload.php' car si tu as dans ton php.ini la condition display_error sur off, il passera cette fonction ...

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    899
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 899
    Par défaut réponse à Fench
    Citation Envoyé par Fench Voir le message
    Bonjour,

    Trois petites choses:
    - Pour ma part, j'éviterais de faire un name et un id ='form' car c aussi le nom de la balise, juste pour un soucis de clareté (mais celà ne doit pas changer grand chose )

    - Ton formulaire fait un post vers 'Enquete_upload.php' alors tu donnes le code de 'enquete.php', mais je pense que celà doit être une erreur qui ne doit pas changer grand chose aussi .

    - Dernier, le truc bête, tu as inclus le fichier 'upload.php' car si tu as dans ton php.ini la condition display_error sur off, il passera cette fonction ...
    *******************************************
    Merçi pour ta réponse, non la condition display error est sur ON, de toute façon quand j'appelle la fonction connectMaBase() hors de la condition
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    if (isset ($_POST['enregistre']))
    ça fonctionne.
    A +

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    899
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 899
    Par défaut réponse à Fench
    Citation Envoyé par Fench Voir le message
    Bonjour,

    Trois petites choses:
    - Pour ma part, j'éviterais de faire un name et un id ='form' car c aussi le nom de la balise, juste pour un soucis de clareté (mais celà ne doit pas changer grand chose )

    - Ton formulaire fait un post vers 'Enquete_upload.php' alors tu donnes le code de 'enquete.php', mais je pense que celà doit être une erreur qui ne doit pas changer grand chose aussi .

    - Dernier, le truc bête, tu as inclus le fichier 'upload.php' car si tu as dans ton php.ini la condition display_error sur off, il passera cette fonction ...
    ***************************
    ********************************************
    Finalement j'ai trouvé la solution, il suffisait de coder le PHP en début de fichier upload après avoir cliqué sur le submit du enquete.php :
    enquete.php : formulaire puis validation avec le submit renvoi vers upload.php
    upload.php codage php de la connexion avec la base et insertion de l'enregistrement.
    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
     
    <?php
    function connectMaBase(){
        $base = mysql_connect ('localhost', 'root', '');  
        mysql_select_db ('Mabase', $base) ;
    }
    ?>
     <?php   
          if (isset ($_POST['enregistre']))
              {
               //   echo"ok enregistre1";
     
     
                //On récupère les valeurs entrées par l'utilisateur :
                $champ1=$_POST['champ1'];
                $champ2=$_POST['champ2'];
                $champ3=$_POST['champ3'];
                $champ4=$_POST['champ4'];
                  //On se connecte    
                connectMabase(); 
             //   echo'etab = '.$etab.';  };     
         $sql = 'INSERT INTO table VALUES("","'.$champ1.'","2013","'.$champ2.'","'.$champ3.'","2012/11/11","'.$champ4.'")';     
     
     
         mysql_query ($sql) or die ('Erreur SQL !'.$sql.'<br />'.mysql_error()); 
     
                // on ferme la connexion
                mysql_close(); 
               }
                   else 
               {
                 echo"non ok enr";
               } 
     
    ?>
    Voilà merçi encore pour ton aide

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. creer connexion base de donné avec dbedit eclipse
    Par youcef81 dans le forum Eclipse Java
    Réponses: 1
    Dernier message: 22/07/2006, 17h37
  2. Connexions permanentes avec la base
    Par zalalus dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 21/07/2006, 12h50
  3. Probleme de connexion JDBC avec une base de donne mysql
    Par sultan_kafila dans le forum JDBC
    Réponses: 19
    Dernier message: 12/04/2006, 08h25
  4. [VB.NET] Problème de connexion à la base avec VB.net
    Par Bqda dans le forum Windows Forms
    Réponses: 13
    Dernier message: 02/04/2006, 13h56
  5. Comment faire une connexion dynamique à une base avec ADO?
    Par Borisam dans le forum Bases de données
    Réponses: 2
    Dernier message: 22/03/2006, 14h22

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