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: 2059740" data-attributes="member: 295036"><p><strong>AW: php - Kontaktformular umbauen</strong></p><p></p><p>@Duddle:</p><p>erst mal vielen Dank für deinen Tipp mit dem besser lesbaren Code.</p><p>Ich versuche so etwas dann immer umzusetzen, da es nach einiger Zeit viel einfacher ist noch mal zu verstehen, was man selber programmiert hat.</p><p></p><p>Die Datei test.php ist die Datei, in der im Moment alles abläuft.</p><p></p><p>Ich setze jetzt mal den kompletten Code dieser Datei hier rein.</p><p></p><p>[PHP]<?</p><p>/***************************************************************************</p><p> * *</p><p> * copyright : (C) 2008 Daniel Kauser *</p><p> * email : danysahne333@mail.ru *</p><p> * website : www.cb-talk.de/captcha.html *</p><p> * *</p><p> * *</p><p> * *</p><p> ***************************************************************************/</p><p></p><p>/***************************************************************************</p><p> * *</p><p> * Diese Script ist gratis. Viele andere Scripte kosten viel Geld doch *</p><p> * ich und zum Glück auch noch ein paar andere sind gegen sowas und *</p><p> * bieten unsere Scripte gratis an. Deshalb löscht nicht den copyright *</p><p> * von mir damit wir kein Stress kriegen *</p><p> * *</p><p> ***************************************************************************/</p><p> </p><p> // 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>// +++++++ in diesen Teil habe ich die komplette Originaldatei kontakt_ausw.php übernommen</p><p>if(isset($_POST['eintrag']) AND $_POST['eintrag']=='eintragen')</p><p>{</p><p> // Session starten und config.php includen</p><p>/*/ +++++++ isession_start() habe ich auskommentiert</p><p> session_start();</p><p>// */</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> $_SESSION['email'] = $_POST['email'];</p><p> $_SESSION['betreff'] = $_POST['betreff'];</p><p> $_SESSION['nachricht'] = $_POST['nachricht'];</p><p> </p><p> $email_i = $_SESSION['email'];</p><p> </p><p> // Email Funktion</p><p> function pruefe_mail($email_i) {</p><p> if(strstr($email_i, "@")) {</p><p> $email_i = explode ("@", $email_i);</p><p> if(strstr($email_i[1], ".")) $ok = TRUE;</p><p> }</p><p> return $ok;</p><p> }</p><p> </p><p> // Eingaben prüfen</p><p> $fehler = "";</p><p> if(!pruefe_mail($email_i) && !empty($email_i)) {</p><p> $fehler .= "<li>Email fehlerhaft!</li>";</p><p> }</p><p> if ($_SESSION['name'] == ""){ </p><p> $fehler .= "<li>Name fehlt!</li>";</p><p> }</p><p> if ($_SESSION['email'] == ""){ </p><p> $fehler .= "<li>Email fehlt!</li>";</p><p> }</p><p> if ($_SESSION['betreff'] == ""){ </p><p> $fehler .= "<li>Betreff fehlt!</li>";</p><p> }</p><p> if ($_SESSION['nachricht'] == ""){ </p><p> $fehler .= "<li>Nachricht fehlt!</li>";</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> // Email zumsammensetzen</p><p> $email = "From: " . $_SESSION['email'];</p><p> $nachrichtfertig = $_SESSION['name']. " schrieb: \n\n" . $_SESSION['nachricht'];</p><p> $versand = mail($empfaenger, $_SESSION['betreff'], $nachrichtfertig, $email);</p><p> if ($versand) {</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> unset($_SESSION['email']);</p><p> unset($_SESSION['betreff']);</p><p> unset($_SESSION['nachricht']);</p><p> }</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']);</p><p>}</p><p>?></p><p></p><p><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"></p><p><html xmlns="http://www.w3.org/1999/xhtml" xml:lang="de" lang="de"></p><p><head></p><p> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /></p><p> <meta http-equiv="language" content="de" /></p><p> <title>Kontaktformular</title></p><p></head></p><p></p><p><body></p><p><div style="border: 1px #000 solid; width: 350px; padding: 5px;"></p><p><h3>Kontaktformular</h3></p><p></p><p><form method="post" action="test.php" name="kontakt"></p><p> <table></p><p> <tr><td><p>Name: </p></td><td><p><input name="name" size="34" type="text" <?if (isset($_SESSION['name'])) { echo 'value="' . $_SESSION['name'] . '"'; }?>/></p></td></tr></p><p> <tr><td><p>Email: </p></td><td><p><input name="email" size="34" type="text" <?if (isset($_SESSION['email'])) { echo 'value="' . $_SESSION['email'] . '"'; }?>/></p></td></tr></p><p> <tr><td><p>Betreff: </p></td><td><p><input name="betreff" size="34" type="text" <?if (isset($_SESSION['betreff'])) { echo 'value="' . $_SESSION['betreff'] . '"'; }?>/></p></td></tr></p><p> <tr><td><p>Nachricht: </p></td><td><p><textarea name="nachricht" rows="3" cols="26"><?if (isset($_SESSION['nachricht'])) { echo $_SESSION['nachricht'] ; }?></textarea></p></td></tr></p><p> </p><p> <tr><td> </td><td><img border="0" src="captcha_img.php?PHPSESSID=<?echo session_id();?>&ver=<?echo time();?>" alt="" /></td></tr></p><p> <tr><td><p>Code: </p></td><td><p><input maxlength="6" name="txtCode" size="34" type="text" /></p></td></tr></p><p> <tr><td> </td><td><p><input class="button" type="submit" name="eintrag" value="eintragen" />&nbsp;<input class="button" type="reset" name="reset" value="l&ouml;schen" /></p></td></tr></p><p> </table></p><p> </div></p><p></form></p><p></body></p><p></html></p><p>[/PHP]Das Script habe ich hier heruntergeladen: </p><p></p><p>und der Autor schreibt:</p></blockquote><p></p>
[QUOTE="Isometric, post: 2059740, member: 295036"] [b]AW: php - Kontaktformular umbauen[/b] @Duddle: erst mal vielen Dank für deinen Tipp mit dem besser lesbaren Code. Ich versuche so etwas dann immer umzusetzen, da es nach einiger Zeit viel einfacher ist noch mal zu verstehen, was man selber programmiert hat. Die Datei test.php ist die Datei, in der im Moment alles abläuft. Ich setze jetzt mal den kompletten Code dieser Datei hier rein. [PHP]<? /*************************************************************************** * * * copyright : (C) 2008 Daniel Kauser * * email : danysahne333@mail.ru * * website : www.cb-talk.de/captcha.html * * * * * * * ***************************************************************************/ /*************************************************************************** * * * Diese Script ist gratis. Viele andere Scripte kosten viel Geld doch * * ich und zum Glück auch noch ein paar andere sind gegen sowas und * * bieten unsere Scripte gratis an. Deshalb löscht nicht den copyright * * von mir damit wir kein Stress kriegen * * * ***************************************************************************/ // 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!"); } // +++++++ in diesen Teil habe ich die komplette Originaldatei kontakt_ausw.php übernommen if(isset($_POST['eintrag']) AND $_POST['eintrag']=='eintragen') { // Session starten und config.php includen /*/ +++++++ isession_start() habe ich auskommentiert 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']; $_SESSION['email'] = $_POST['email']; $_SESSION['betreff'] = $_POST['betreff']; $_SESSION['nachricht'] = $_POST['nachricht']; $email_i = $_SESSION['email']; // Email Funktion function pruefe_mail($email_i) { if(strstr($email_i, "@")) { $email_i = explode ("@", $email_i); if(strstr($email_i[1], ".")) $ok = TRUE; } return $ok; } // Eingaben prüfen $fehler = ""; if(!pruefe_mail($email_i) && !empty($email_i)) { $fehler .= "<li>Email fehlerhaft!</li>"; } if ($_SESSION['name'] == ""){ $fehler .= "<li>Name fehlt!</li>"; } if ($_SESSION['email'] == ""){ $fehler .= "<li>Email fehlt!</li>"; } if ($_SESSION['betreff'] == ""){ $fehler .= "<li>Betreff fehlt!</li>"; } if ($_SESSION['nachricht'] == ""){ $fehler .= "<li>Nachricht 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 == ""){ // Email zumsammensetzen $email = "From: " . $_SESSION['email']; $nachrichtfertig = $_SESSION['name']. " schrieb: \n\n" . $_SESSION['nachricht']; $versand = mail($empfaenger, $_SESSION['betreff'], $nachrichtfertig, $email); if ($versand) { echo '<h3>Kontaktformular</h3> <p>Email ist erfolgreich versendet worden!</p>'; // Sessionvariablen löschen unset($_SESSION['name']); unset($_SESSION['email']); unset($_SESSION['betreff']); unset($_SESSION['nachricht']); } } 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']); } ?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="de" lang="de"> <head> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> <meta http-equiv="language" content="de" /> <title>Kontaktformular</title> </head> <body> <div style="border: 1px #000 solid; width: 350px; padding: 5px;"> <h3>Kontaktformular</h3> <form method="post" action="test.php" name="kontakt"> <table> <tr><td><p>Name: </p></td><td><p><input name="name" size="34" type="text" <?if (isset($_SESSION['name'])) { echo 'value="' . $_SESSION['name'] . '"'; }?>/></p></td></tr> <tr><td><p>Email: </p></td><td><p><input name="email" size="34" type="text" <?if (isset($_SESSION['email'])) { echo 'value="' . $_SESSION['email'] . '"'; }?>/></p></td></tr> <tr><td><p>Betreff: </p></td><td><p><input name="betreff" size="34" type="text" <?if (isset($_SESSION['betreff'])) { echo 'value="' . $_SESSION['betreff'] . '"'; }?>/></p></td></tr> <tr><td><p>Nachricht: </p></td><td><p><textarea name="nachricht" rows="3" cols="26"><?if (isset($_SESSION['nachricht'])) { echo $_SESSION['nachricht'] ; }?></textarea></p></td></tr> <tr><td> </td><td><img border="0" src="captcha_img.php?PHPSESSID=<?echo session_id();?>&ver=<?echo time();?>" alt="" /></td></tr> <tr><td><p>Code: </p></td><td><p><input maxlength="6" name="txtCode" size="34" type="text" /></p></td></tr> <tr><td> </td><td><p><input class="button" type="submit" name="eintrag" value="eintragen" /> <input class="button" type="reset" name="reset" value="löschen" /></p></td></tr> </table> </div> </form> </body> </html> [/PHP]Das Script habe ich hier heruntergeladen: und der Autor schreibt: [/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