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

HTML Discussion :

charger une page sans tout recharger


Sujet :

HTML

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    119
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 119
    Points : 55
    Points
    55
    Par défaut charger une page sans tout recharger
    bonjour

    voila je suis entrain de créer un site proffesionnel mais j'ai un petit soucis alors j'en appel a votre aide...

    j'ai crée ma page index.php et ma feuilel de style css

    dans mon index.php j'include le header ainsi que le menu et je voudrais savoir comment faire pour intégrer le contenu de la page selectionner sans avoir a tout recharger et sans utiliser de ca
    <?
    $page = $_GET['page'];
    include("$page.php");
    ?>

    puisque parait-il que c'est dangereux niveau sécurité ?



    quelqu'un a une solution
    j'espre avoir ete assez clair.

  2. #2
    Rédacteur
    Avatar de _Mac_
    Profil pro
    Inscrit en
    Août 2005
    Messages
    9 601
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 9 601
    Points : 12 977
    Points
    12 977
    Par défaut
    Tu peux t'en sortir en maintenant une liste des pages autorisées en include.

    Sinon, y a l'autre solution qui consiste à faire un include du header et du menu dans chaque page.

    Du détail, du détail, du détail !!!
    Revenons à la source : lisons la documentation et les fichiers de trace, la réponse à notre problème s'y trouve sans doute

  3. #3
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,

    En effet c'est dangeureux au niveau sécurité. Dans la doc de include on peut lire :
    Si les Gestionnaires d'URL sont activés dans PHP (ce qui est le cas par défaut), vous pouvez localiser le fichier avec une URL (via HTTP ou bien avec un gestionnaire adapté : voir Annexe M pour une liste des protocoles), au lieu d'un simple chemin local.
    C'est à dire qu'avec le code suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
        <?
        $page = $_GET['page'];
        include("$page.php");
        ?>
    Et que tu lances ta page avec le paramètre ?page=http://www.google.com alors la page d'acceuil de Google sera incluse dans ta page...
    Le danger c'est qu'au lieu de rediriger vers Google il y ai une redirection vers une page imitant un formulaire de ton site (style connection de l'utilisateur), ce qui permettrai de renvoyer les données utilisateurs vers un autre site...


    Le moyen le plus simple de le sécuriser est de spécifier un répertoire dans lequel se trouveront toutes les pages à inclure, et de spécifier ce répertoire dans include :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
        <?
        $page = $_GET['page'];
        include( "./included/" . "$page.php");
        ?>
    De cette manière si le paramètre page correspond à une adresse vers un autre site tu auras une erreur de include()...

    a++

  4. #4
    Membre éprouvé
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    1 012
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 1 012
    Points : 1 093
    Points
    1 093
    Par défaut
    encore que la solution d'adiguba résoud probablement le problème, on m'a toujours dit que pour ces mêmes raisons de sécurité il faut carrément éviter ce genre de code

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    119
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 119
    Points : 55
    Points
    55
    Par défaut
    en faite j'ai utilisé les includes

    je fais un test de la page voir si le nom est correct si oui je l'affiche sinon je retourne a l'acceuil

    on verra ce que ca donnera

  6. #6
    Membre éprouvé
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    1 012
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 1 012
    Points : 1 093
    Points
    1 093
    Par défaut
    oui mais si tu fais un test c'est que tu possèdes quelque part un tableau pour comparer la page à charger avec les pages existantes

    je ne comprends toujours pas, mais suis peut-être trop ignorant, pourquoi tu ne fais pas un include de la page en clair au lieu de la passer en paramètre...

  7. #7
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 637
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 637
    Points : 66 662
    Points
    66 662
    Billets dans le blog
    1
    Par défaut
    sinon en xmlhttprequest ...
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  8. #8
    Membre du Club
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    119
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 119
    Points : 55
    Points
    55
    Par défaut
    bin je sais pas ce que j'ai fait c'est pas bien ?

    si je pose c'est pour avoir des conseil

    merci bien

  9. #9
    Membre expérimenté

    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 278
    Points : 1 639
    Points
    1 639
    Par défaut
    Je milite pour la liste blanche à propos des pages à inclure.
    Ou alors, tester la présence de caractères dangereux (du style ../ ou http), puis la présence du fichier demandé dans un répertoire dont l'adresse est codée en dur, et enfin inclure.

  10. #10
    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
    Moi j'utilise ca
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <div id="corps">
    <?php 
    $pageOK = array(        '1' => 'acceuil.php',
                                            '2' => 'contact.php',
                                            '3' => 'profil.php');
    if (!isset($_GET['page'])){ $_GET['page'] = "news";}
    if ( (isset($_GET['page'])) && (isset($pageOK[$_GET['page']])) ) include($pageOK[$_GET['page']]);?>
    </div>
    Mais comme le dit dit Spacefrog, charger des données sans recharger la page c'est xmlhttprequest ...

  11. #11
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 637
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 637
    Points : 66 662
    Points
    66 662
    Billets dans le blog
    1
    Par défaut
    merci voisin de l'espaaaaaace
    je pensais encore une fois avoir été transparent
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  12. #12
    Membre du Club
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    119
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 119
    Points : 55
    Points
    55
    Par défaut
    ouais bin j'utilise ca moi aussi

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    <?php
      // On définit le tableau contenant les pages autorisées
      // ----------------------------------------------------
      $pageOK = array('australie' => 'australie.php',
                      'toeic' => 'toeic.php',
                      'accueil' => 'accueil.php');
     
      // On teste que le paramètre d'url existe et qu'il est bien autorisé
      // -----------------------------------------------------------------
      if ( (isset($_GET['page'])) && (isset($pageOK[$_GET['page']])) ) {
        include($pageOK[$_GET['page']]);   // Nous appelons le contenu central de la page
      } else {
        include('accueil.php');   // Page par défaut quant elle n'existe pas dans le tableau
      }
      ?>
    c'est bon ca ?

Discussions similaires

  1. Actualiser une page sans en recharger les images, les sons.
    Par scarlatine dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 01/01/2013, 22h08
  2. [AJAX] Raffraichir une page sans la recharger
    Par JClens dans le forum AJAX
    Réponses: 3
    Dernier message: 17/09/2010, 16h02
  3. Charger une page sans recharger le menu flash
    Par overtrack dans le forum ActionScript 1 & ActionScript 2
    Réponses: 0
    Dernier message: 27/04/2009, 12h25
  4. Modifier une page sans la recharger...
    Par Ylias dans le forum Général JavaScript
    Réponses: 12
    Dernier message: 10/05/2006, 11h06
  5. Déplacement dans une page sans recharge
    Par EpOnYmE187 dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 30/08/2005, 16h17

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