bedingtes Include

Einklappen
X
 
  • Filter
  • Zeit
  • Anzeigen
Alles löschen
neue Beiträge

  • bedingtes Include

    Was PHP angeht bin ich leider noch ein Newbie ...
    Ich habe jetzt durch googeln bzw. mein Vorwissen von anderen Programmiersprachen den einen PHP code zu schreiben.

    Leider wird der Code nicht so abgearbeitet wie ich mir das vorstelle:

    PHP-Code:
    <?php
        
    ## INHALT DYNMAISCH ERZEUGEN ## 
          
    $content $_GET["lifeonair"] . ".php";
        
        
        
         include(
    'header.php');
        
        
        
    //wenn noch kein Link geklickt wurde, öffne die Datei 'start.php' 
          
    if(!$content) { 
               include(
    "start.php"); 
             exit; 
          } 
        
    // Sicherheitsproblem unterbinden ************ 
          
    if (strtolower(substr($content,0,7)) == "http://" || 
              
    strtolower(substr($content,0,8)) == "https://" || 
              
    strtolower(substr($content,0,6)) == "ftp://"){ 
               include(
    "fehlerseite.php"); 
               exit; 
          } 
          else if (!
    file_exists($content)){ 
               include(
    "fehlerseite.php"); 
               exit; 
          } 

        
    //wenn $content einen Inhalt hat, öffne diesen 
          
    include($content); 

        
        
        include(
    'sidebar.php');
        include(
    'footer.php');
    ?>

    was der Code eigentlich machen soll ist folgendes:

    wenn keine Referenz also bsp. (index.php&lifeonair=links) - sprich wenn ich nur: index.php eintippe dann möchte ich, dass die "start.php" datei importiert wird.
    das eben was nicht geht.
    Wo liegt der Fehler?
    wenn ich index.php eintippe - dann wird sofort die Fehlerseite angezeigt.

    Danke für eure Hilfe schon im Voraus.
    Zuletzt geändert von cool_water_at; 01.08.2007, 12:06.

  • #2
    die() statt exit() verwenden.

    Kommentar


    • #3
      Das ist Murks. Du schaffst eine Sicherheitslücke.

      Mach es so:

      Ein Array mit allen erlaubten Seitennamen
      Abfrage, ob einer davon übergeben wurde, und nur dann includieren, andernfalls start.php einbinden

      PHP-Code:
      if (isset($_GET['lifeonair']) && in_array($_GET['lifeonair'], $allowed_pages)) include($_GET['lifeonair'] . ".php");
      else include(
      "start.php"); 
      die() statt exit() verwenden.
      Wieso?
      ich glaube

      Kommentar


      • #4
        $allowed_pages ??

        ist dan die Variable für ein Array?
        könntest du bitten ein Beispiel posten - danke!

        Kommentar


        • #5
          halte dich an http://tut.php-q.net/frames.html und den rest der seite.

          Kommentar


          • #6
            Das Beispiel steht doch schon da. Du musst nur noch ein Array mit deinen Seiten anlegen. (In dem Bespiel heißt das $allowed_pages, aber das kannst du ja ändern).
            ich glaube

            Kommentar


            • #7


              vielen dank das wird mir weiter helfen!
              Zuletzt geändert von cool_water_at; 01.08.2007, 18:52.

              Kommentar


              • #8
                mal ne andere frage: wie kann nach
                PHP-Code:
                      $content $_GET["lifeonair"] . ".php"
                folgendes if noch wie gewünscht funktionieren?
                PHP-Code:
                      if(!$content) { 
                           include(
                "start.php"); 
                         exit; 
                      } 
                nach der zuweisung steht doch mindestens ".php" in $content, oder nicht???
                Zuletzt geändert von w-shadow; 16.08.2007, 15:53.

                Kommentar


                • #9
                  Mach mal ein var_dump() des if-Ausdrucks und von $content. Ich glaub das nämlich nicht ...

                  Kommentar


                  • #10
                    Original geschrieben von onemorenerd
                    Mach mal ein var_dump() des if-Ausdrucks und von $content. Ich glaub das nämlich nicht ...
                    und wie geht das ?

                    var_dump($content) ???

                    und dann??
                    Zuletzt geändert von cool_water_at; 05.08.2007, 09:37.

                    Kommentar


                    • #11
                      Array.

                      hallo noch mal

                      ich habe nun das mit dem Array probiert - es wird leider noch immer nur die start.php angezeigt:

                      auch wenn im meinem Webbrowser "index.php?lifeonair=empfang" eintippe - die datei ist vorhanden.

                      PHP-Code:
                          ## LIFE ON AIR ARRAY für erlaubte Links ## 

                          
                      $allowed_pages = array(); // ein Leeres Array erzeugen    
                          
                      $allowed_pages['start'];
                          
                      $allowed_pages['empfang'];
                          
                      $allowed_pages['links'];
                          
                          
                       
                          include(
                      'header.php');
                          
                          
                          if (isset(
                      $_GET['lifeonair']) && in_array($_GET['lifeonair'], $allowed_pages)) { 
                              
                              include(
                      $_GET['lifeonair'] . ".php");
                          
                          }
                          
                          
                          else {
                              include(
                      "start.php");
                          }

                          
                          
                          include(
                      'sidebar.php');
                          include(
                      'footer.php'); 

                      Kommentar


                      • #12
                        Das Array ist leer. Im Manual unter "Arrays" anschauen, wie man Elemente zuweist.

                        Kommentar


                        • #13
                          PHP-Code:
                          <?php
                              
                          ## LIFE ON AIR ARRAY für erlaubte Links ## 

                              
                          $allowed_pages = array(); // ein Leeres Array erzeugen    
                              
                          $allowed_pages['start']="start.php";
                              
                          $allowed_pages['empfang']="empfang.php";
                              
                          $allowed_pages['links']="links.php";
                              
                              
                           
                              include(
                          'header.php');
                              
                              
                              if (isset(
                          $_GET['lifeonair']) && in_array($_GET['lifeonair'], $allowed_pages)) { 
                                  
                                  include(
                          $_GET['lifeonair'] . ".php");
                              
                              }
                              
                              
                              else {
                                  include(
                          "start.php");
                              }

                              
                              
                              include(
                          'sidebar.php');
                              include(
                          'footer.php');
                          ?>



                          Am Array ist es leider nicht gelegen - es wird leider noch immer nur die start.php seite angezeigt


                          PHP-Code:
                              include $allowed_pages[$_GET['lifeonair']]; 
                          statt
                          PHP-Code:
                                  include($_GET['lifeonair'] . ".php"); 
                          nützt leider auch nichts
                          Zuletzt geändert von cool_water_at; 05.08.2007, 13:33.

                          Kommentar


                          • #14
                            $_GET['lifeonair'] ist ja auch nicht "empfang.php" sondern "empfang".

                            array_key_exists
                            Zuletzt geändert von onemorenerd; 05.08.2007, 13:41.

                            Kommentar


                            • #15
                              Hallo
                              ich möchte zu dem Array noch eine wechselnde Header grafik machen.

                              sprich ich brauche ein Variable und in die Variable soll jedes Mal ein Bild reingeladen werden sofern man eine Seite aufruft.


                              empfang: soll ein eignes Bild haben
                              start soll ein eigenes Bild haben.

                              wie kann ich dass dazu programmieren?

                              Kommentar

                              Lädt...
                              X