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 :

antislashs et guillemets: problemes!


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 57
    Par défaut antislashs et guillemets: problemes!
    Salut a tous,

    J’ai un champ texte de table MySQL que je veux afficher dans une page web sous la forme d’un input text : input type = ”text” value = ...

    Certains enregistrements de cette table contiennent des guillemets qui font echouer la requete d'SQL insertion, c’est pourquoi avant d'inserer dans la table j’utilise la fonction mysql_real_escape_string, qui place un \ avant chaque guillemet.

    Pour ne pas afficher ces \, j’utilise la fonction stripslashes juste avant l’affichage. Le probleme est que dans ce cas la, ca n’affiche rien !

    Si je n’utilise pas stripslashes, ca affiche bien le contenu mais avec des \” tout laids. Si j’essaie de virer les \ avec stripslashes, plus rien ne s'affiche. Comment resoudre ce probleme ?

  2. #2
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    un p'tit bout de code peut-être ?

    pcq perso, ça, ça marche (bon ok c'est codé à la barbare je sais :s)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    <?php
    $txt = 'Voici un texte qu\'il est bô';
    echo '<input type="text" value="'.stripslashes($txt).'" />';
    ?>

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 57
    Par défaut
    Salut,

    Ton bout de code marche aussi chez moi, mais si tu remplaces le ' par un " dans ta chaine $txt = 'Voici un texte qu\'il est bô', ca ne marche plus: ce qui vient apres le " (il est bô) ne s'affiche pas. Et c'est vraiment ca mon probleme, c'est les guillemets (par les quotes) !

  4. #4
    Membre émérite Avatar de Korko Fain
    Profil pro
    Étudiant
    Inscrit en
    Août 2005
    Messages
    632
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Août 2005
    Messages : 632
    Par défaut
    Ah mais c'est un autre probleme ça lol

    Je te montre en prenant l'exemple précédent :

    Un utilisateur entre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Voici un texte qu'il est bô
    Tu l'insere en SQL sans protection :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mysql_query('Voici un texte qu'il est bô');
    Evidemment, ça plante. Maintenant avec mysql_real_escape_string()
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mysql_query('Voici un texte qu\'il est bô');
    Ok ça passe. Maintenant on affiche sans rien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo '<input type="text" value="Voici un texte qu\'il est bô" />';
    Ok et avec stripslashes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo '<input type="text" value="Voici un texte qu'il est bô" />';
    Ok toujours. Mais avec un " cette fois-ci, c'est ton HTML qui est cassé :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo '<input type="text" value="Voici un texte qu"il est bô" />';
    La solution:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    function encode($txt) {
        $txt = stripslashes($txt);
        $txt = str_replace('"', '\"', $txt);
        return $txt;
    }
     
    echo '<input type="text" value="'.encode($txt)." />';

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 57
    Par défaut
    Merci mais ca ne marche pas! Ce code, qui utilise ta fonction :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $chaine="Le \"clavier\" magique";
    $chaine=encode($chaine);
    echo '<input type="text" value="'.encode($chaine).'" />';
    .. affiche un input contenant : Le \

  6. #6
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $chaine="Le \"clavier\" magique";
    $chaine=htmlentities(stripslashes($chaine));
    echo '<input type="text" value="'.$chaine.'" />';

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

Discussions similaires

  1. Réponses: 9
    Dernier message: 28/10/2005, 12h43
  2. [MySQL] probleme d'antislash avec ereg_replace
    Par photorelief dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 13/10/2005, 12h27
  3. [JSP][SQL]Probleme de guillemets avec SQL
    Par Drizzt [Drone38] dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 29/08/2005, 19h39
  4. Probleme avec guillemets dans commande HREF
    Par angelevil dans le forum ASP
    Réponses: 4
    Dernier message: 02/05/2005, 20h06
  5. [VB.NET] Probleme de guillemet
    Par poypoy75 dans le forum ASP.NET
    Réponses: 3
    Dernier message: 08/02/2005, 19h21

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