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 :

Insertion variable MySQL [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Mai 2007
    Messages
    262
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Mai 2007
    Messages : 262
    Par défaut Insertion variable MySQL
    Bonjour,

    J'ai un petit soucis avec une variable dans un formulaire qui me renvoi une chaine de caractères.

    Tout marche très bien, sauf si ma chaine de caractères contient un caractère spécial (', ou ",...).

    Je ne comprends pas pourquoi car une autre variable fait la même chose mais tt marche pr elle...

    Cette variable est créée dans un formulaire puis envoyer vers une autre page :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $repOuv=addslashes($_POST['repOuv']);
    Dans un premier temps, lorsque je l'affiche, elle est OK avec les slash si besoin.
    Ex :
    c\'est clair.

    Donc le pb ne vient pas de là.
    Ensuite, je l'envoi vers une autre page grâce à un champ caché de form :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <input type='hidden' name='var5' value='<?php echo $repOuv; ?>'/>
    Lors de la récupération de cette variable, j'ai une erreur qui apparait à l'écran lors de l'insertion en BDD :
    => Erreur de syntaxe près de 'c\'est clair',...

    Elle est traitée dans cette page comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $repOuv=stripslashes($_POST['var5']);
    Voila j'espère que vous pourrez m'aider et si vous avez besoin de code ou de quoique se soit n'hésitez pas.

    Merci d'avance !

  2. #2
    Membre Expert

    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    1 138
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Octobre 2002
    Messages : 1 138
    Par défaut
    peux tu faire un echo de ta requete et la poster ici s'il te plait.

    De plus, je te conseille plutot de faire un mysql_real_escape_string() sur ta variable quand tu la passes dans la requete plutôt qu'un addslashes.

  3. #3
    Membre éclairé
    Inscrit en
    Mai 2007
    Messages
    262
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Mai 2007
    Messages : 262
    Par défaut
    Pas de pb pour faire un echo de ma requete mais celle ci se propage sur 3 pages.

    Dans la première, je récupère ma valeur( ca marche)
    Dans la seconde je l'affiche une première fois (ca marche)
    Dans la dernière je souhaite l'insérer dans ma base et soucis...

    Si je fais un echo dans ma dernière page, ca donne :

    (si ma variable = c'est cool)
    -> c\

    Voila et une erreur lors de l'insertion des données (logique)
    Je pense que c'est à cause du addslashes mais je ne sais oas comment résoudre ce pb...

  4. #4
    Membre éclairé
    Inscrit en
    Mai 2007
    Messages
    262
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Mai 2007
    Messages : 262
    Par défaut
    Comment utilises tu
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mysql_real_escape_string()
    avec une variable ???

    Merci d'avance

  5. #5
    Membre émérite Avatar de trattos
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    1 000
    Détails du profil
    Informations personnelles :
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 000
    Par défaut
    Utilise htmlentities(); pour l'affiche de tes données provenant d'un formulaire.

  6. #6
    Membre éclairé
    Inscrit en
    Mai 2007
    Messages
    262
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Mai 2007
    Messages : 262
    Par défaut
    Pour l'affichage des données ton htmlentities m'interresse mais malheuresement, rien ne change.

    Si ma variable = c'est clair

    Il m'affiche :

    c

    Il ne détecte pas après le guillemet...

    Voila tte solution est bonne à prendre !!!

  7. #7
    Membre expérimenté

    Profil pro
    Inscrit en
    Juin 2002
    Messages
    6 152
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 6 152
    Par défaut
    La fonction htmlentities ne remplacera pas les apostrophes sans utiliser son deuxième paramètre facultatif et sans lui spécifier la valeur ENT_QUOTES. L'avez-vous fait ?

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

Discussions similaires

  1. Insertion dans MySQL depuis un champ texte à deux variables
    Par Anibel dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 29/01/2013, 11h48
  2. [MySQL] INSERT dans mysql d une variable ponctuee
    Par deluxerabbit dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 02/11/2010, 17h41
  3. Réponses: 1
    Dernier message: 27/05/2010, 14h14
  4. [SGBD] [Problème insertion variable php/mysql]
    Par vincedjs dans le forum Installation
    Réponses: 20
    Dernier message: 08/02/2006, 16h41
  5. Problème d'insertion avec MySQL
    Par Sonny dans le forum ASP
    Réponses: 13
    Dernier message: 28/08/2003, 13h52

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