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 :

[Tableaux] Petit Soucis d'URL


Sujet :

Langage PHP

  1. #1
    Inscrit Avatar de sanosuke85
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 206
    Points : 179
    Points
    179
    Par défaut [Tableaux] Petit Soucis d'URL
    Bonjour,

    Je viens à vous tous car j'ai un petit soucis. On est venu me voir en mail pour me dire que mon site avait une faille Ce qui est sympathique de la part de la personne qui me l'a fait remarquer ^^

    Voici l'adresse :

    Le site en question

    Je vous fais un copier coller du message :

    il me semble que tu as une faille include en local Voila
    http://ombre.et.lumiere.free.fr/index.php?page=../index
    Le mieux c'est de mettre en dur tes conditions, if($page==index)
    include(Index.. elseif($page==) .... else { include page defo }
    Si vous pouviez m'aider à comprendre pourquoi cette faille existe s'il vous plaît... Car avec son lien la page boucle sur elle-même à n'en plus finir ^^ Heureusement que c'est chez free sinon le stress pour la bande passante

  2. #2
    Membre confirmé Avatar de supermanu
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    330
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2004
    Messages : 330
    Points : 452
    Points
    452
    Par défaut
    Je pense que ce qu'il a voulu dire c'est que passer le nom et le chemin de ta page à afficher n'est pas sécurisé. En effet je dois pouvoir inclure une de mes pages à la place de la tienne et y mettre le code que je veux. Par exemple une requête SQL pour détruire toute tes tables.
    Donc le mieux c'est de passer une variable dans le lien.
    De faire le test sur cette variable et d'inclure la bonne page.

  3. #3
    Membre confirmé
    Profil pro
    Développeur Web
    Inscrit en
    Avril 2006
    Messages
    430
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Avril 2006
    Messages : 430
    Points : 557
    Points
    557
    Par défaut
    Salut,

    le problème réside dans le fait que tu ne contrôles pas assez ce que le user peut passer en paramètre via la variable $page.

    Avec l'exemple que la personne t'as donné, il te montre qu'on peut réinclure le fichier index.php dans lui-même.
    En fait, on peut passer n'importe quel nom de fichier en paramètre, et remonter ou descendre dans l'arborescence des répertoires.
    Une limite existe déjà, à savoir que tu as rajouté automatiquement le '.php' à la fin, donc c'est déjà ca de pris.

    La solution pour éviter ce genre de problèmes est de bien contrôler que ce que le user passe via le param page est autorisé, et peut l'amener quelque part.
    Du style:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    switch($_GET['page']) {
      case 'actu': include 'pages/actus.php'; break
      case 'test': include 'pages/test.php'; break
      default: include 'pages/erreur.php'; break
    }
    Voila l'idée.

  4. #4
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Points : 18 681
    Points
    18 681
    Par défaut
    tu as du faire un truc du genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    include($_GET['page'].".php");

    tu devrais plutôt gérer une table associative du genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $index["index"] = "index.php";
    $page = ($index[$_GET['page']] != "") ? $index[$_GET['page']] : $index['accueil'];
    include($page);
    enfin, on peut raffiner

  5. #5
    Inscrit Avatar de sanosuke85
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 206
    Points : 179
    Points
    179
    Par défaut
    Bonjour à tous,

    je reviens pour ma question (pardon de ne pas avoir répondu avant). Je comprends mieux le soucis de sécurité et je vous en remercie. Cependant du coup faire ainsi on perd le système dynamique d'inclusion des fichiers. Mais bon si c'est pour une bonne sécurité vaut mieux

    Donc le but est d'indiquer toutes les inclusions qui peuvent être faites afin d'éviter qu'une autre, non autorisée, soit effectuée ?

  6. #6
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Points : 18 681
    Points
    18 681
    Par défaut
    Citation Envoyé par sanosuke85
    Bonjour à tous,

    je reviens pour ma question (pardon de ne pas avoir répondu avant). Je comprends mieux le soucis de sécurité et je vous en remercie. Cependant du coup faire ainsi on perd le système dynamique d'inclusion des fichiers. Mais bon si c'est pour une bonne sécurité vaut mieux

    Donc le but est d'indiquer toutes les inclusions qui peuvent être faites afin d'éviter qu'une autre, non autorisée, soit effectuée ?

    sinon tu considères que toutes les pages pouvant être incluses sont dans un répertoire donné... et avec une expression regulière tu retires les ".." et les "http://" ou "ftp://"

    en plus, vu que tu as rajouté include("monrepertoire/".$page.".php") tu es sûr qu'il ne va pas inclure la page dans elle même... infiniement

    et le tour est joué...

  7. #7
    Membre confirmé Avatar de stunti
    Inscrit en
    Mai 2006
    Messages
    520
    Détails du profil
    Informations personnelles :
    Âge : 46

    Informations forums :
    Inscription : Mai 2006
    Messages : 520
    Points : 594
    Points
    594
    Par défaut
    tu peux verifier si le fichier existe avant de l'inclure.
    comme ca pas de pb. (verifie quand meme qu'il se trouve dans ton arbo de source PHP et que tu n'inclue pas /etc/passwd)

  8. #8
    Invité
    Invité(e)
    Par défaut
    sans oublier a tout ça le fameux isset
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(isset($_GET["page"])){...}

  9. #9
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Points : 18 681
    Points
    18 681
    Par défaut
    Citation Envoyé par stunti
    tu peux verifier si le fichier existe avant de l'inclure.
    comme ca pas de pb. (verifie quand meme qu'il se trouve dans ton arbo de source PHP et que tu n'inclue pas /etc/passwd)

    pas seulement.... sinon on peut inclure la même page dans cette page, et ça tournera en boucle

  10. #10
    Membre confirmé Avatar de stunti
    Inscrit en
    Mai 2006
    Messages
    520
    Détails du profil
    Informations personnelles :
    Âge : 46

    Informations forums :
    Inscription : Mai 2006
    Messages : 520
    Points : 594
    Points
    594
    Par défaut
    Citation Envoyé par gorgonite
    pas seulement.... sinon on peut inclure la même page dans cette page, et ça tournera en boucle


    include_once require_once.

  11. #11
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Points : 18 681
    Points
    18 681
    Par défaut
    Citation Envoyé par stunti
    include_once require_once.

    mais tu peux toujours inclure une fois la page dans elle-même...

  12. #12
    Membre confirmé Avatar de stunti
    Inscrit en
    Mai 2006
    Messages
    520
    Détails du profil
    Informations personnelles :
    Âge : 46

    Informations forums :
    Inscription : Mai 2006
    Messages : 520
    Points : 594
    Points
    594
    Par défaut
    effectivement.
    un petit test a rajouter en plus.

  13. #13
    Inscrit Avatar de sanosuke85
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 206
    Points : 179
    Points
    179
    Par défaut
    Je vous remercie pour toutes vos réponses

    En fait, j'aurais une question d'ordre général : y'a-t-il un topic, ou un tutorial, sur toutes les bases de sécurités à connaître sur notre site (php, mysql etc) ? Les sécurités élémentaires en gros... Si vous en connaissez un, je serai ravi de le connaître

    Pardon d'abuser de questions...

  14. #14
    Invité
    Invité(e)
    Par défaut
    voila un long topic http://www.developpez.net/forums/showthread.php?t=12254

    (facilement trouvable dans la section securité vu que c'est le premier tout en haut)

  15. #15
    Inscrit Avatar de sanosuke85
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 206
    Points : 179
    Points
    179
    Par défaut
    * tout honteux *

    Merci et sincèrement désolé ......... Oui j'avoue j'ai posé la question là rapidement en lisant les réponses qui m'ont été données... J'ai pas cherché pardon pardon !!!

    (ps : tiens au cas où les admin liraient, pour ma part je trouvais la présentation du forum avant beaucoup moins "fouillli" là j'arrive plus à m'y retrouver ^^ question d'habitude je pense mais j'ai vraiment du mal )

    Merci rbaatouc en tout cas

  16. #16
    Invité
    Invité(e)
    Par défaut
    je ne suis pas admin mais peronnellement je la trouve bcp plus clair maintenant.
    tu as de sections appropriées a chaque pb, c'est mieux car tu ty retrouve bcp plus vite au lieu de chercher parmis des milliers de messages.
    je pense que c'est juste une question dhabitude à prendre

  17. #17
    Inscrit Avatar de sanosuke85
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 206
    Points : 179
    Points
    179
    Par défaut
    Effectivement il y'a plus de "sujets" c'est mieux classé

    Mais c'est plus côté visuel où ça fait un peu "pâté"

    Mais oui une fois habitué ça ira je pense

  18. #18
    Invité
    Invité(e)
    Par défaut
    visuel c sur c pas trés clair (au début mais on sy fait rapidement) mais bon moi je recherche le coté pratique et la il y est.

Discussions similaires

  1. Petit souci avec les tableaux de sqlparameter
    Par zooffy dans le forum ASP.NET
    Réponses: 3
    Dernier message: 20/09/2011, 13h36
  2. [MySQL] Petit soucis d'url rewriting
    Par tryan dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 07/11/2010, 15h16
  3. Petit souci avec URL Rewriting
    Par jhdscript dans le forum Apache
    Réponses: 6
    Dernier message: 18/06/2008, 09h02
  4. [Tableaux] petit soucis avec "echo"
    Par bruno bdf dans le forum Langage
    Réponses: 1
    Dernier message: 29/03/2007, 23h33
  5. [DEBUTANT] petits soucis avec un prgm de chat
    Par LechucK dans le forum MFC
    Réponses: 8
    Dernier message: 19/01/2004, 16h52

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