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 :

json_encode() MySQL apostrophe addslashes()


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Inscrit en
    Avril 2008
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 13
    Points : 10
    Points
    10
    Par défaut json_encode() MySQL apostrophe addslashes()
    Bonjour,

    Je fait un JSON a partir de mes données dans ma BD comme ceci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $req = mysql_query("SELECT ...");
    $rows = array();
    while($row = mysql_fetch_assoc($req)) {
    $rows[] = $row;
    }
    $data = json_encode($rows);
    Ce qui fait la même chose que ce tableau

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $array = array(
    "nom"=>utf8_encode("Mélanie"),
    "prénom"=>utf8_encode("Roussillon"),
    "test"=>"L\'apostrophe"
    );
     
    $data = json_encode($array);
     
    echo $data;
    Ce qui donne

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    {"nom":"M\u00e9lanie",null:"Roussillon","test":"L\\'apostrophe"}
    Le problème c'est que je fais un addslashes a insertion des données ce qui ajoute un slash ce qui est normal mais avec json_encode() ça cause le problème d'ajout de deux slashs (L\\'apostrophe) j'ai essayer de l'enlever avec stripslashes, str_replace mais sans succès.

    Savez-comment régler ce problème.

    Merci

  2. #2
    Expert éminent sénior

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Points : 10 726
    Points
    10 726
    Par défaut
    Citation Envoyé par davland7 Voir le message
    je fais un addslashes a insertion des données ce qui ajoute un slash
    nop, dans ta base le slash ne doit pas y être, vérifie tes magic_quotes

  3. #3
    Membre actif
    Homme Profil pro
    Inscrit en
    Décembre 2004
    Messages
    174
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Décembre 2004
    Messages : 174
    Points : 241
    Points
    241
    Par défaut
    Tiens, un petit tuyau.
    Une fonction pour protéger tes données quand tu veux les insérer dans ta base :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    fonction protect($value){
      if (get_magic_quotes_gpc()) { // si on a get_magic_quotes_gpc, alors on stripslash les values en entrée
        $value = stripslashes($value);
      }
    // on quote si c'est pas du numérique
      if (!is_numeric($value)) {
        $value = "'" . mysql_real_escape_string($value) . "'";
      }
      return $value;
    }
    Après, chacun en fait ce qu'il veut !

    Et comme dit ci-dessus : pas d'addslashes....
    NginX, SphinxSearch Addict !!

  4. #4
    Membre à l'essai
    Inscrit en
    Avril 2008
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 13
    Points : 10
    Points
    10
    Par défaut
    Merci, si je comprend bien les magic quotes ajoute les \ au apostrophe et avec mes addslashes je les ajoutes en double, alors il serai mieux pour moi que je les désactives.

  5. #5
    Membre actif
    Homme Profil pro
    Inscrit en
    Décembre 2004
    Messages
    174
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Décembre 2004
    Messages : 174
    Points : 241
    Points
    241
    Par défaut
    Citation Envoyé par davland7 Voir le message
    Merci, si je comprend bien les magic quotes ajoute les \ au apostrophe et avec mes addslashes je les ajoutes en double, alors il serai mieux pour moi que je les désactives.
    NginX, SphinxSearch Addict !!

Discussions similaires

  1. [MySQL] Mysql apostrophe récalcitrante
    Par fazpedro dans le forum PHP & Base de données
    Réponses: 13
    Dernier message: 24/09/2011, 12h17
  2. [MySQL] problème mysql : apostrophe dans une requête
    Par stars333 dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 31/03/2010, 10h18
  3. [MySQL] Mysql, apostrophe et champ input
    Par BenoitDenis dans le forum PHP & Base de données
    Réponses: 11
    Dernier message: 30/03/2010, 15h57
  4. [MySQL] Mysql et addslashes() php
    Par cilies38 dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 05/05/2009, 07h52
  5. [JDBC]Java MYSQL - Remplacer les apostrophes
    Par RapidJul dans le forum JDBC
    Réponses: 3
    Dernier message: 08/11/2005, 16h31

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