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 :

Insérer une entrée via une variable JS [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2015
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2015
    Messages : 38
    Par défaut Insérer une entrée via une variable JS
    Bonjour à tous!

    Je fais des tests sur WAMP, je code en PHP serveur Apache et BDD MySQL et j'ai une question au sujet d'un INSERT dans une BDD:



    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
                                   <?php
                                            //On essaie de se connecter à ma base de données 'test2'
                                             try{
    						$bdd = new PDO('mysql:host=localhost;dbname=test2;charset=utf8', 'root', '', array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION));
     
    					 }catch (Exception $e){
     							die('Erreur : ' . $e->getMessage());
    					 }
     
    					//On insère des balises SCRIPT pour pouvoir utiliser un Prompt
    					echo   "<script type='text/javascript'> 
    								var c = prompt('Contenu?');
    								var t = prompt('Titre?');
    							</script>";
     
                                                    //On récupère les valeurs des variables JS dans des variables PHP, et les valeurs sont bien récupérées
    						$contenu = "<script type='text/javascript'> document.write(c); </script>";
    						$titre =   "<script type='text/javascript'> document.write(t); </script>";
     
    				                //On prépare une requête pour  insérer les valeurs des variables PHP des entrées souhaitées dans la table new
    						$req = $bdd->prepare('INSERT INTO new(Contenu, Titre) VALUES(:contenu, :titre)');
    						$req->execute(array('contenu' => $contenu, 'titre' => $titre));
     
                                                    //On affiche chaque entrée de la table avant de fermer le curseur de requête
    				 		$reponse = $bdd->query('SELECT * FROM new');
    						while ($donnees = $reponse->fetch()){
    							echo $donnees['ID'].$donnees['Titre'].$donnees['Contenu']."<br/>";						
    						}
    						$reponse->closeCursor();

    Voici mon problème:
    Les variables récupérées du Prompt sont correctes MAIS quand j'affiche ma table après y avoir inséré une ligne, toutes les entrées sont devenues identiques à la dernière que j'ai choisie via ces deux prompts! Pourquoi svp?

    Je précise que lorsque je remplace:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    	                        //Utiliser Prompt avec JS
    					echo   "<script type='text/javascript'> 
    								var c = prompt('Contenu?');
    								var t = prompt('Titre?');
    							</script>";
     
    						$contenu = "<script type='text/javascript'> document.write(c); </script>";
    						$titre =   "<script type='text/javascript'> document.write(t); </script>";
    Par:
    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
     
    <form action="test.php" method="post">
    		<input type="text" name="contenu"></input>
    		<input type="text" name="titre"></input>
    		<input type="submit" name="ok"></input>
    		</form>
     
                                      <?php
                                             //Utiliser un formulaire
                                              if(isset($_POST['ok'])){
                                                  .....
                                              $contenu = $_POST['contenu'];
    						$titre = $_POST['titre'];
                                                  .....
                                              }
                                          ?>
    Cela fonctionne mais je vous demande ici pourquoi cela ne fonctionne pas comme je le souhaite avec JS mais me remplace chaque entrée.

    Merci d'avance pour votre considération

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    PHP est exécuté par le serveur. Ensuite Javascript est executé par le client. Javascript ne peut donc pas intervenir dans le code PHP.
    Pourquoi veux-tu faire des prompt qui sont moches plutôt qu'un formulaire ?
    Si tu te ballades sur Internet tu verras beaucoup de formulaire et jamais de prompt.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2015
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2015
    Messages : 38
    Par défaut
    PHP est exécuté par le serveur. Ensuite Javascript est executé par le client. Javascript ne peut donc pas intervenir dans le code PHP.
    Pourquoi veux-tu faire des prompt qui sont moches plutôt qu'un formulaire ?
    Si tu te ballades sur Internet tu verras beaucoup de formulaire et jamais de prompt.
    En effet pour JS Client et PHP Serveur, j'ai utilisé un formulaire du coup comme mentionné à la fin;

    mais ma question était: comment cela est-il possible qu'un INSERT unique modifie toutes les entrées antérieures dans ma BDD?

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Ce n'est pas possible.
    Tu as une requête UPDATE qui traine dans l'histoire.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2015
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2015
    Messages : 38
    Par défaut
    Ce n'est pas possible.
    Tu as une requête UPDATE qui traine dans l'histoire.
    Je t'assure que non
    Je fais juste des petits tests, je ne suis pas encore un expert:
    Ici j'ai créé ma BDD nommée 'test2', ma table nommée 'new' ainsi que ses champs ID/Contenu/Titre via PhpMyAdmin.
    En utilisant le code php que j'ai donné au début ( en y ajoutant ?> pour clôturer php car j'ai du tronquer par erreur), ça me donne ce souci de remplacement, mon programme est donc très simple ( pas de sécurité ou autres protocoles avancés, ou traitement, etc...) je ne fais que faire un INSERT puis afficher ma table, d'où mon questionnement!

    Edit: Pour moi ce qui pourrait être en cause à première vue serait la partie du code ou je fais prepare() puis exec(), mais comme je ne m'y connais pas autant que vous je suis venu ici gagner du temps.
    Et merci pour ta considération en passant

  6. #6
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Tu as contrôlé dans Phpmyadmin ?
    Ta table doit être remplie de "<script type='text/javascript'> document.write(c); </script>"
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2015
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2015
    Messages : 38
    Par défaut
    Tu as contrôlé dans Phpmyadmin ?
    Ta table doit être remplie de "<script type='text/javascript'> document.write(c); </script>"

    Bonjour, et désolé du retard j'ai eu quelques préoccupations IRL.

    En effet cela a rempli mes tables de "<script type='text/javascript'> document.write(c); </script>" , du coup pour l'utilisateur ça lui affiche ce qu'il entre, je n'avais pas vu .

    Merci beaucoup sabotage! Sujet résolu

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

Discussions similaires

  1. [Toutes versions] Supprimer l'entrée d'une table via une liste déroulante
    Par mixnake dans le forum IHM
    Réponses: 4
    Dernier message: 20/04/2013, 07h33
  2. [AC-2003] Lier les tables d'une Base1 dans une Base3 via une Base2
    Par ted the Ors dans le forum VBA Access
    Réponses: 0
    Dernier message: 30/12/2009, 11h58
  3. Réponses: 14
    Dernier message: 10/09/2009, 19h08
  4. [XL-2003] Insérer la valeur d'une cellule dans une phrase d'une autre
    Par DonaldTron dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 05/04/2009, 19h50
  5. Réponses: 2
    Dernier message: 17/04/2007, 17h14

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