Problem mit Captcha in Templatesystem

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

  • Problem mit Captcha in Templatesystem

    Guten Morgen,

    ich habe vor einiger Zeit ein Templatesystem auf der Basis des Tutorials von php-quake.net geschrieben. Nun wollte ich gerne einen Bereich durch ein Captcha schützen. Jedoch kommt es da zu einigen für mich komplett unverständlichen Problemen.

    Ich habe mal testweise einfach irgend einen Tutorial Test-Code genommen, der normalerweise ganz normal funktioniert.

    captcha.php
    PHP-Code:
    <?php
    // Session starten
    session_start();
    // Alten CAPTCHA-Code aus der Session loeschen
    unset( $_SESSION['captcha_code'] );
     
    // Das Cachen der Grafik verhindern
    header"Expires: Mon, 26 Jul 1997 05:00:00 GMT" );
    header"Last-Modified: " gmdate("D, d M Y H:i:s") . " GMT" );
    header"Cache-Control: no-store, no-cache, must-revalidate" );
    header"Cache-Control: post-check=0, pre-check=0"false );
    header"Pragma: no-cache" );
     
    // Dem Browser mitteilen das es sich hierbei um ein JPG handelt.
    header'Content-type: image/jpeg' );
     
    // Sicherheitscode generieren
    $AlphaNumerischerString "ABCDEFGH2345689";
    $_SESSION['captcha1'] = substrstr_shuffle$AlphaNumerischerString ), 0);
    $_SESSION['captcha2'] = substrstr_shuffle$AlphaNumerischerString ), 0);
    $_SESSION['captcha3'] = substrstr_shuffle$AlphaNumerischerString ), 0);


    // Grafik erzeugen und an den Browser senden
    $Schriftarten = array( "zachary.ttf""mtcorsva.ttf""gilligan.ttf");
    $Bilddatei imagecreatefrompng"hintergrund.png" );
    $TextFarbe1 imagecolorallocate$Bilddatei0125);
    $TextFarbe2 imagecolorallocate$Bilddatei1307090 );
    $TextFarbe3 imagecolorallocate$Bilddatei18090190 );
    imagettftext$Bilddatei1215324$TextFarbe1$Schriftarten[0], $_SESSION['captcha1'] );
    imagettftext$Bilddatei1602615$TextFarbe2$Schriftarten[1], $_SESSION['captcha2'] );
    imagettftext$Bilddatei14, -205318$TextFarbe3$Schriftarten[2], $_SESSION['captcha3'] );
    imagejpeg$Bilddatei );
     
    // Grafik zerstören und Speicher freigeben
    imagedestroy$Bilddatei );
    ?>
    Eingebunden wird die captcha.php in eine .tpl Datei.

    test.tpl
    HTML-Code:
    <img src="captcha.php" />
    So nun zu den Ereignissen, die ich nicht verstehe ...

    1. Seitenaufruf

    Grafik Captcha-Code: 111111
    Session Captcha-Code: Session ist nicht vorhanden

    2. Seitenaufruf

    Grafik Captcha-Code: 222222
    Session Captcha-Code: 111111

    3. Seitenaufruf

    Grafik Captcha-Code: 333333
    Session Captcha-Code: 222222

    Irgendwie fehlt mir an der Stelle ein bisschen logisches denken glaube ich. Woran kann das liegen?



    Mit freundlichen Grüßen:

    Micha

  • #2
    Vermutlich gibst du die Sessiondaten in dem Script aus, welches das Image-Tag erzeugt. Doch der Captcha Code wird erst in einem späteren Request erzeugt, wenn der Browser das Bild, also Captcha.php abruft.
    Das ist okay.

    Kommentar


    • #3
      Hallo,

      wenn dein "Session Captcha-Code" jeweils eine Testausgabe auf derselben Seite (die auch das Bild enthält) ist, klingt das völlig logisch. Erst wird die Seite geladen, dann das Bild was in dieser Seite enthalten ist. Erst beim Laden des Bildes wird die Session aktualisiert. Wenn du den Code eingibst und dann abschickst, kann der Code mit der inzwischen aktualisierten Session abgeglichen werden und eine neue Seite wird erzeugt. Diese enthält aber vermutlich wieder ein Captcha-Bild dessen Generierung die Session aktualisiert. Das Bild ist also völlig zu recht immer einen Schritt voraus.

      Edit: Danke onemorenerd, ich finde es immer wieder interessant, zu sehen, wie man das was ich sagen will auch in 2 Sätzen ausdrücken kann.

      Gruß,

      Amica
      [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
      Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
      Super, danke!
      [/COLOR]

      Kommentar


      • #4
        Oh ... vielen Dank =)

        Ihr habt Recht gehabt. Ich lasse mein Formular während der Eingabe durch ein Ajax-Request überprüfen, somit ist es ja dann auch klar, dass der Vergleich der beiden Werte immer false ergibt.

        Noch einmal vielen Dank Ihr zwei

        Kommentar

        Lädt...
        X