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

Requêtes MySQL Discussion :

[SGBD] Utilisation de mysql_real_escape_string()


Sujet :

Requêtes MySQL

  1. #1
    Membre averti Avatar de Space Cowboy
    Homme Profil pro
    chomeur
    Inscrit en
    Avril 2005
    Messages
    496
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : chomeur

    Informations forums :
    Inscription : Avril 2005
    Messages : 496
    Points : 401
    Points
    401
    Par défaut [SGBD] Utilisation de mysql_real_escape_string()
    Je cherche a savoir comment utiliser cette fonction, j'ai cru comprendre qu'il n'y avais pas mieux.

    Avant, quand je voulais enregistrer une requete dans ma BDD, je faisais un addslashes() sur la variables avant de l'inserer dans la requete. Ce qui fait que dans la BDD il y avait des \ devant les ' ".

    J'ai vus dans la doc php une facon d'utilisais cette fonction :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $quete_date 	= 'NOW()';
    $quete_jeux 	= 'aaaaa';
    $quete_ville 	= 'bbb bbb';
    $quete_nom 		= 'cccc';
    $quete_text 	= "ddddddi l'apppa ddddd '' ddddd";
     
    $sql = sprintf("INSERT INTO fo_quete (quete_date ,quete_jeux, quete_ville, quete_nom, quete_text) VALUES(NOW(), '%s', '%s', '%s', '%s' )",	
    				mysql_real_escape_string($quete_jeux),
    				mysql_real_escape_string($quete_ville),
    				mysql_real_escape_string($quete_nom),
    				mysql_real_escape_string($quete_text));
    $res = mysql_query($sql);
    Est elle mieux que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $sql='INSERT INTO fo_quete (quete_date,quete_jeux,quete_ville,quete_nom,quete_text)
    			VALUES(
    					"' . mysql_real_escape_string($quete_date)	.'", 
    					"' . mysql_real_escape_string($quete_jeux)	.'", 
    					"' . mysql_real_escape_string($quete_ville)	.'", 
    					"' . mysql_real_escape_string($quete_nom)		.'", 
    					"' . mysql_real_escape_string($quete_text)	.'" )'; 
    $res = mysql_query($sql);
    J'ai remarquer que cette fonctionne ajouter des \ au variables, mais seulement à l'envoie, mysql apparament supprimer les \ dans la BDD.

    J'en fait une utilisation correcte niveau sécurité ?

  2. #2
    Expert confirmé
    Avatar de siddh
    Inscrit en
    Novembre 2005
    Messages
    3 868
    Détails du profil
    Informations personnelles :
    Âge : 48

    Informations forums :
    Inscription : Novembre 2005
    Messages : 3 868
    Points : 5 011
    Points
    5 011
    Par défaut
    j'allais te dire qu'il faut faire gaffe aux magic_quotes

    mais sur http://fr2.php.net/manual/fr/functio...ape-string.php

    ils donnent l'exemple 3 :
    L'utilisation de la fonction mysql_real_escape_string() sur chaque variable évite les injections SQL. Cet exemple démontre la méthode la plus propre pour envoyer une requête à la base, indépendamment de votre configuration des guillemets magiques.
    Ce qui fait que tu peux prendre exemple sur celui la et que ce sera sécurisé comme il faut.

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

Discussions similaires

  1. [A-03] Quel SGBD utilise vraiment Access ?
    Par MaxLaMenaX dans le forum Access
    Réponses: 3
    Dernier message: 02/12/2008, 15h49
  2. Quel SGBD utiliser ?
    Par gids01 dans le forum JDBC
    Réponses: 6
    Dernier message: 19/07/2007, 10h15
  3. [MySQL] [SGBD] [mssql] Equivalent mysql_real_escape_string pour mssql
    Par PoZZyX dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 03/10/2005, 12h37
  4. Quel SGBD utiliser??
    Par 78alex78 dans le forum Bases de données
    Réponses: 3
    Dernier message: 25/04/2005, 19h28

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