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 :

[SQL] Simples quotes échappés automatiquement ?


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Inscrit en
    Septembre 2005
    Messages
    64
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 64
    Points : 44
    Points
    44
    Par défaut [SQL] Simples quotes échappés automatiquement ?
    Bonjour à tous,

    je récupere la gestion d'un site web que je dois refondre
    et apres avoir vu le code du système de login, je pensais qu'il était
    vulnérable à une injection SQL.
    En effet, voici le code (simplifié) du formulaire index.php:
    Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    <form action="login.php" method="post" name="formulaire">
    <input type="text" name="user">
    <input type="password" name="pass">
    Puis le code de login.php (ce sont vraiment les premieres lignes du formulaire, je n'ai rien enlevé), les variables $user et $pass sont récupérés via le système de register_globals qui est sur on :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    $link = mysql_connect("localhost", "admin_login", "admin_pass")
    or die ("Impossible de se connecter");
     
    mysql_select_db ("BD")
    or die ("Impossible d'accéder à la base de données");
     
    session_start();
    $req="select login,iduser from personnel where login='$user' and password='$pass';";
    $res=mysql_query($req);
    En etudiant le code, je me suis dit qu'en saisissant dans la page web le login :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ';drop table personnel;
    , c'était censé réaliser une injection SQL puis effacer la table cependant ... non.
    Lorsque j'affiche le contenu de la variable $req je vois :
    select login,iduser from personnel where login='\';drop table personnel;' and password='test';
    Mon simple quote a été automatiquement échappé. Savez-vous quel mécanisme a pu réaliser cela sachant qu'aucune fonction d'échappement n'est utilisée dans le code?
    Bon je me prends la tete pour pas grand chose mais j'aimerai comprendre...
    Merci,a +

  2. #2
    Expert éminent Avatar de Mr N.
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 5 418
    Points : 6 449
    Points
    6 449
    Par défaut
    cela vient de magic_quotes_gpc

  3. #3
    Membre du Club
    Inscrit en
    Septembre 2005
    Messages
    64
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 64
    Points : 44
    Points
    44
    Par défaut
    ok, vu dans la config php.ini .
    Merci beaucoup pour la rapidité de ta réponse!

  4. #4
    Membre éclairé 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
    Points : 718
    Points
    718
    Par défaut
    Fait attention, avec l'arrivée de PHP6, ces possibilités de sécurité du serveur vont disparaitre, a toi de securiser tes applications php.

  5. #5
    Membre du Club
    Inscrit en
    Septembre 2005
    Messages
    64
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 64
    Points : 44
    Points
    44
    Par défaut
    oui, merci du conseil !
    C'est clair que c'est vraiment pas top comme code...

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

Discussions similaires

  1. [MySQL] transformer une simple quote en double pour un insert !!
    Par st0nky dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 11/01/2006, 16h38
  2. [text] probleme avec simple quote
    Par bor1s dans le forum Langage SQL
    Réponses: 3
    Dernier message: 22/12/2005, 16h03
  3. Aide Pour Requete SQL Simple ... Merci d'avance :)
    Par thefutureisnow dans le forum Langage SQL
    Réponses: 3
    Dernier message: 09/12/2005, 11h39
  4. Probleme avec encodage de simple quote
    Par linkowich dans le forum Langage
    Réponses: 2
    Dernier message: 31/10/2005, 13h16
  5. Plantage requete SQL simple sous Delphi7/ADO avec Access
    Par tomy29 dans le forum Bases de données
    Réponses: 2
    Dernier message: 25/08/2005, 11h09

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