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 :

Sécurité de l'include


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    48
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 48
    Points : 41
    Points
    41
    Par défaut Sécurité de l'include
    Bonjour, j'aimerais connaitre votre avis concernant la sécurité d'une page php lors de l'include d'un fichier.

    La question :
    Lors de la création d'un fichier est il suffisant d'ajouter un remplacement des caractères < et > par &lt et &gt; Pour ensuite inclure ce fichier dans une page PHP.
    Je sais par exemple qu'au niveau de la requête Mysql un simple addslashes ne suffit absolument pas, car on peut jouer sur le jeu de caractères. Est-il le cas sur ses symboles.

    Un exemple :
    Il y a deux pages actualite.php et actu-1.html. Le fichier actualité va générer le fichier actu-1.htlm (qui sera en réalité le cache de la page de cette actualité).
    Si la page actu-1.htlm est d'actualité, la page actualite.php va l'inclure.

    Lorsqu'un utilisateur va ajouter un commentaire sous cette actualité, la page actualite.php va mettre en cache la nouvelle page puis l'inclure.
    Mais l'utilisateur peux mettre comme commentaire : « je tente un hack <?php echo "test"; ?> » sans protection,
    on verra apparaitre : « je tente un hack test ».

    Si je remplace les symboles < et > par &lt et &gt;, ceci est il une sécurité complètement suffisante ou nom.

    PS : J'utilise une include car cette même page de cache contient un script PHP à exécuter (affichage du pseudo du membre si il est connecter par exemple). Je préfère éviter de séparer le code en deux page pour le côté pratique et les ressource du serveur.

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Tu as des fonctions comme striptags() et htmlspecialchars() qui oeuvrent dans ce sens.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    48
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 48
    Points : 41
    Points
    41
    Par défaut
    Merci, htmlspecialchars me semble superflu, car je ne souhaite pas modifier les guillemets.
    Je voulais être sûr qu'avec un simple str_replace par exemple se serait suffisant.
    Ou connaitre une fonction sûre

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 44
    Points : 31
    Points
    31
    Par défaut
    sinon tu t'assure que ton fichier existe avec file_exists()

Discussions similaires

  1. include et vérification dans un array pour la sécurité
    Par jalex-jalex dans le forum Langage
    Réponses: 3
    Dernier message: 21/11/2008, 11h40
  2. [Sécurité] La faille include
    Par adeltimple dans le forum Langage
    Réponses: 18
    Dernier message: 26/05/2008, 22h43
  3. Réponses: 7
    Dernier message: 12/01/2006, 20h50
  4. Réponses: 4
    Dernier message: 13/12/2005, 10h19
  5. [Sécurité] Include
    Par Skarlix dans le forum Langage
    Réponses: 4
    Dernier message: 20/11/2005, 01h23

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