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, Sicherheit und Fragen
Beitrag
<blockquote data-quote="Duddle" data-source="post: 2261342" data-attributes="member: 17775"><p><strong>AW: PHP-Kontaktformular, Sicherheit und Fragen</strong></p><p></p><p></p><p>Dein Muster in check_email() beachtet sie derzeit auch nicht. </p><p></p><p>Folgende Zeilen haben keine Funktion:</p><p>[PHP]</p><p>//Validierung</p><p> check_name($name);</p><p> check_email($email);</p><p> check_nachricht($nachricht);}</p><p>[/PHP]</p><p>In [PHP]if (check_name($name) && check_email($email) && check_nachricht($nachricht) ==true) {[/PHP]</p><p>muss das "==true" nicht sein, da du die boolschen Rückgabewerte mit UND verknüpfst. Ist eines davon <em>false</em>, wird der gesamte Ausdruck <em>false</em>.</p><p>Bei sowas wie [PHP]// Abfrage ob alles gesetzt und ausggefüllt wurde</p><p> if (isset($_POST['abs_name']) && isset($_POST['abs_email']) && isset($_POST['abs_nachricht']) &&</p><p> !empty($name) && !empty($email) && !empty($nachricht)) { [/PHP]</p><p>könntest du eine Hilfsfunktion einführen, damit du am Ende sowas schreiben kannst wie [PHP] if(isDefined($name) && isDefined($email) ...[/PHP] Ich sehe keinen Mehrwert darin, an diesem Punkt noch zwischen "$_POST['abs_name']" und "$name" zu unterscheiden.</p><p>Weiterhin würde ich wohl die Fehlerabfragen defensiver strukturieren. Das heisst, erst auf Fehler prüfen und entsprechend handeln, danach ist es per Definition fehlerfrei. Grob gesagt, statt</p><p>[PHP]</p><p>if(isDefined($foo) && isDefined($bar)) {</p><p> mail();</p><p>} else {</p><p> $error = "";</p><p> if(!isDefined($foo)) $error .= $foo;</p><p> if(!isDefined($bar)) $error .= $bar;</p><p>}</p><p>[/PHP]</p><p>lieber sowas</p><p>[PHP]</p><p>$error = "";</p><p>if(!isDefined($foo)) $error .= $foo;</p><p>if(!isDefined($bar)) $error .= $bar;</p><p></p><p>if($error == "") {</p><p> mail();</p><p>}</p><p>[/PHP]</p><p>Das Ergebnis ist das selbe, der Code aber sauberer und einfacher zu erweitern.</p><p>Eines noch:</p><p>[PHP]</p><p>foreach ($abs_eingaben as $key => $value)</p><p> $abs_eingaben[$key]=entfernen($value);</p><p>[/PHP]</p><p>Schau dir <a href="http://us1.php.net/manual/en/function.array-map.php" target="_blank">array_map()</a> an.</p><p></p><p></p><p>Duddle</p></blockquote><p></p>
[QUOTE="Duddle, post: 2261342, member: 17775"] [b]AW: PHP-Kontaktformular, Sicherheit und Fragen[/b] Dein Muster in check_email() beachtet sie derzeit auch nicht. Folgende Zeilen haben keine Funktion: [PHP] //Validierung check_name($name); check_email($email); check_nachricht($nachricht);} [/PHP] In [PHP]if (check_name($name) && check_email($email) && check_nachricht($nachricht) ==true) {[/PHP] muss das "==true" nicht sein, da du die boolschen Rückgabewerte mit UND verknüpfst. Ist eines davon [I]false[/I], wird der gesamte Ausdruck [I]false[/I]. Bei sowas wie [PHP]// Abfrage ob alles gesetzt und ausggefüllt wurde if (isset($_POST['abs_name']) && isset($_POST['abs_email']) && isset($_POST['abs_nachricht']) && !empty($name) && !empty($email) && !empty($nachricht)) { [/PHP] könntest du eine Hilfsfunktion einführen, damit du am Ende sowas schreiben kannst wie [PHP] if(isDefined($name) && isDefined($email) ...[/PHP] Ich sehe keinen Mehrwert darin, an diesem Punkt noch zwischen "$_POST['abs_name']" und "$name" zu unterscheiden. Weiterhin würde ich wohl die Fehlerabfragen defensiver strukturieren. Das heisst, erst auf Fehler prüfen und entsprechend handeln, danach ist es per Definition fehlerfrei. Grob gesagt, statt [PHP] if(isDefined($foo) && isDefined($bar)) { mail(); } else { $error = ""; if(!isDefined($foo)) $error .= $foo; if(!isDefined($bar)) $error .= $bar; } [/PHP] lieber sowas [PHP] $error = ""; if(!isDefined($foo)) $error .= $foo; if(!isDefined($bar)) $error .= $bar; if($error == "") { mail(); } [/PHP] Das Ergebnis ist das selbe, der Code aber sauberer und einfacher zu erweitern. Eines noch: [PHP] foreach ($abs_eingaben as $key => $value) $abs_eingaben[$key]=entfernen($value); [/PHP] Schau dir [URL=http://us1.php.net/manual/en/function.array-map.php]array_map()[/URL] an. Duddle [/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, Sicherheit und Fragen
Oben