PSD-Tutorials.de
Forum für Design, Fotografie & Bildbearbeitung
Tutkit
Agentur
Hilfe
Kontakt
Start
Forum
Aktuelles
Besonderer Inhalt
Foren durchsuchen
Tutorials
News
Anmelden
Kostenlos registrieren
Aktuelles
Suche
Suche
Nur Titel durchsuchen
Von:
Menü
Anmelden
Kostenlos registrieren
App installieren
Installieren
JavaScript ist deaktiviert. Für eine bessere Darstellung aktiviere bitte JavaScript in deinem Browser, bevor du fortfährst.
Du verwendest einen veralteten Browser. Es ist möglich, dass diese oder andere Websites nicht korrekt angezeigt werden.
Du solltest ein Upgrade durchführen oder einen
alternativen Browser
verwenden.
Antworten auf deine Fragen:
Neues Thema erstellen
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
php - Kontaktformular umbauen
Beitrag
<blockquote data-quote="Isometric" data-source="post: 2059258" data-attributes="member: 295036"><p><strong>AW: php - Kontaktformular umbauen</strong></p><p></p><p>Mit Sessions habe ich bis jetzt noch gar keine Erfahrung <img src="/styles/default/xenforo/smilies/uhm.gif" class="smilie" loading="lazy" alt=":(" title="Frown :(" data-shortname=":(" /></p><p></p><p>Ich habe den php-Teil von kontakt_ausw.php in die kontakt.php kopiert und in eine Bedingung gesetzt, dass dieser Teil erst ausgeführt wird, wenn ich auf "eintragen" gedrückt habe.</p><p>Damit startet das Script schon mal durch.</p><p>Nach dem Drücken von "eintragen" kommt gleich die Fehlermeldung, dass schon eine Session läuft und die Variable ok in der Email-Funktion nicht gefunden wird. Außerdem wird das Captcha-Bild nicht regeneriert.</p><p>Das Löschen des zweiten Session-Starts bringt mich auch nicht weiter. Dann ist zwar die erste Fehlermeldung weg, aber die zweite bleibt und das Captcha-Bild wird auch nicht regeneriert.</p><p></p><p></p><p>[PHP] // Header</p><p> header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); // Datum aus Vergangenheit</p><p> header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); </p><p> // immer geändert</p><p> header("Cache-Control: no-store, no-cache, must-revalidate"); // HTTP/1.1</p><p> header("Cache-Control: post-check=0, pre-check=0", false);</p><p> header("Pragma: no-cache"); // HTTP/1.0</p><p> </p><p> // Alle Fehler und Notices anzeigen</p><p> error_reporting(E_ALL);</p><p> </p><p> session_start();</p><p> </p><p> $CAPTCHA_TempString="";</p><p> </p><p> // Zufallsfunktion für Zahlen und Buchstaben</p><p> function GetRandomChar() {</p><p> </p><p> // Zufallszahl generieren</p><p> mt_srand((double)microtime()*1000000);</p><p> $CAPTCHA_RandVal = mt_rand(1,2);</p><p> </p><p> // Buchstabensalat generieren jeh nachdem ob Randval 1 oder 2 ist</p><p> switch ($CAPTCHA_RandVal) {</p><p> case 1:</p><p> // Zahlen 0-9</p><p> $CAPTCHA_RandVal = mt_rand(48, 57);</p><p> break;</p><p> case 2:</p><p> // Grosse Buchstaben</p><p> $CAPTCHA_RandVal = mt_rand(65, 90);</p><p> break;</p><p> }</p><p> </p><p> // Zufallscode ausgeben</p><p> return chr($CAPTCHA_RandVal);</p><p> }</p><p> </p><p> // Zufallscode x-stellig ausgeben</p><p> for ($i = 1; $i <= 6; $i++) {</p><p> $CAPTCHA_TempString .= GetRandomChar();</p><p> }</p><p></p><p> // Text in Sessionvariable speichern</p><p> if (isset($CAPTCHA_TempString)) {</p><p> $_SESSION["CAPTCHA_RndText"] = str_replace('I','E',str_replace('0','3',str_replace('1','S',str_replace('B','F',str_replace('O','P',str_replace('4','A',str_replace('D','K',$CAPTCHA_TempString)))))));</p><p> } else {</p><p> die("Zufallscode konnte nicht generiert werden!");</p><p> }</p><p>?>[/PHP]Danach kommt der HTML-Teil, mit dem die nächste Datei aufgerufen wird</p><p></p><p>[PHP] // Session starten und config.php includen</p><p> session_start();</p><p> include ("config.php");</p><p> </p><p> // CaptchaCodes abfragen</p><p> $CAPTCHA_RandomText = "";</p><p> if (isset($_POST['txtCode'])){</p><p> $CAPTCHA_EnteredText = str_replace("<","",str_replace(">","",str_replace("'","",str_replace("[","",str_replace("]","",$_POST['txtCode'])))));</p><p> }</p><p> if (isset($_SESSION['CAPTCHA_RndText'])) {</p><p> $CAPTCHA_RandomText = $_SESSION['CAPTCHA_RndText'];</p><p> }</p><p></p><p> // Eingabefelder abfragen</p><p> $_SESSION['name'] = $_POST['name'];</p><p></p><p> // Eingaben prüfen</p><p> $fehler = "";</p><p></p><p> if ($_SESSION['name'] == ""){ </p><p> $fehler .= "<li>Name fehlt!</li>";</p><p> }</p><p> }</p><p> if ($CAPTCHA_EnteredText == $CAPTCHA_RandomText and isset($_POST['txtCode']) == true and isset($_SESSION['CAPTCHA_RndText'])){</p><p> $captcha = true;</p><p> } else {</p><p> $fehler .= "<li>Captcha fehlt oder fehlerhaft!</li>";</p><p> }</p><p> echo '<div style="border: 1px #000 solid; width: 350px; padding: 5px;">'; </p><p> if ($fehler == ""){</p><p> echo '<h3>Kontaktformular</h3></p><p> <p>Email ist erfolgreich versendet worden!</p>';</p><p> </p><p> // Sessionvariablen löschen</p><p> unset($_SESSION['name']);</p><p> }</p><p> } else {</p><p> echo '<h3>Kontaktformular</h3>';</p><p> echo $fehler;</p><p> echo '<p><a href="kontakt.php">zurück</a></p>';</p><p> }</p><p> echo '</div>'; </p><p></p><p> // Session unset</p><p> unset($_SESSION['CAPTCHA_RndText']);[/PHP]Ich bräuchte den Ansatz, wie ich es schaffe das Problem mit den beiden Sessions aus der Welt zu schaffen.</p></blockquote><p></p>
[QUOTE="Isometric, post: 2059258, member: 295036"] [b]AW: php - Kontaktformular umbauen[/b] Mit Sessions habe ich bis jetzt noch gar keine Erfahrung :( Ich habe den php-Teil von kontakt_ausw.php in die kontakt.php kopiert und in eine Bedingung gesetzt, dass dieser Teil erst ausgeführt wird, wenn ich auf "eintragen" gedrückt habe. Damit startet das Script schon mal durch. Nach dem Drücken von "eintragen" kommt gleich die Fehlermeldung, dass schon eine Session läuft und die Variable ok in der Email-Funktion nicht gefunden wird. Außerdem wird das Captcha-Bild nicht regeneriert. Das Löschen des zweiten Session-Starts bringt mich auch nicht weiter. Dann ist zwar die erste Fehlermeldung weg, aber die zweite bleibt und das Captcha-Bild wird auch nicht regeneriert. [PHP] // Header header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); // Datum aus Vergangenheit header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); // immer geändert header("Cache-Control: no-store, no-cache, must-revalidate"); // HTTP/1.1 header("Cache-Control: post-check=0, pre-check=0", false); header("Pragma: no-cache"); // HTTP/1.0 // Alle Fehler und Notices anzeigen error_reporting(E_ALL); session_start(); $CAPTCHA_TempString=""; // Zufallsfunktion für Zahlen und Buchstaben function GetRandomChar() { // Zufallszahl generieren mt_srand((double)microtime()*1000000); $CAPTCHA_RandVal = mt_rand(1,2); // Buchstabensalat generieren jeh nachdem ob Randval 1 oder 2 ist switch ($CAPTCHA_RandVal) { case 1: // Zahlen 0-9 $CAPTCHA_RandVal = mt_rand(48, 57); break; case 2: // Grosse Buchstaben $CAPTCHA_RandVal = mt_rand(65, 90); break; } // Zufallscode ausgeben return chr($CAPTCHA_RandVal); } // Zufallscode x-stellig ausgeben for ($i = 1; $i <= 6; $i++) { $CAPTCHA_TempString .= GetRandomChar(); } // Text in Sessionvariable speichern if (isset($CAPTCHA_TempString)) { $_SESSION["CAPTCHA_RndText"] = str_replace('I','E',str_replace('0','3',str_replace('1','S',str_replace('B','F',str_replace('O','P',str_replace('4','A',str_replace('D','K',$CAPTCHA_TempString))))))); } else { die("Zufallscode konnte nicht generiert werden!"); } ?>[/PHP]Danach kommt der HTML-Teil, mit dem die nächste Datei aufgerufen wird [PHP] // Session starten und config.php includen session_start(); include ("config.php"); // CaptchaCodes abfragen $CAPTCHA_RandomText = ""; if (isset($_POST['txtCode'])){ $CAPTCHA_EnteredText = str_replace("<","",str_replace(">","",str_replace("'","",str_replace("[","",str_replace("]","",$_POST['txtCode']))))); } if (isset($_SESSION['CAPTCHA_RndText'])) { $CAPTCHA_RandomText = $_SESSION['CAPTCHA_RndText']; } // Eingabefelder abfragen $_SESSION['name'] = $_POST['name']; // Eingaben prüfen $fehler = ""; if ($_SESSION['name'] == ""){ $fehler .= "<li>Name fehlt!</li>"; } } if ($CAPTCHA_EnteredText == $CAPTCHA_RandomText and isset($_POST['txtCode']) == true and isset($_SESSION['CAPTCHA_RndText'])){ $captcha = true; } else { $fehler .= "<li>Captcha fehlt oder fehlerhaft!</li>"; } echo '<div style="border: 1px #000 solid; width: 350px; padding: 5px;">'; if ($fehler == ""){ echo '<h3>Kontaktformular</h3> <p>Email ist erfolgreich versendet worden!</p>'; // Sessionvariablen löschen unset($_SESSION['name']); } } else { echo '<h3>Kontaktformular</h3>'; echo $fehler; echo '<p><a href="kontakt.php">zurück</a></p>'; } echo '</div>'; // Session unset unset($_SESSION['CAPTCHA_RndText']);[/PHP]Ich bräuchte den Ansatz, wie ich es schaffe das Problem mit den beiden Sessions aus der Welt zu schaffen. [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ▲ = 7, ▼ = 3, ◇ = 2 und die Summe von ▲ und ▼ durch ◇ geteilt wird, was ist das Ergebnis?
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
php - Kontaktformular umbauen
Oben