php.de

Zurück   php.de > Webentwicklung > PHP Einsteiger

PHP Einsteiger PHP Problemlösungen für Spracheinsteiger
Archive: 2004, 2004/2, 2005, 2005/2, 2006, 2007, 2008, 2009, 2010,

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 13.01.2012, 22:21  
Neuer Benutzer
 
Registriert seit: 29.11.2011
Beiträge: 4
PHP-Kenntnisse:
Anfänger
Starfox befindet sich auf einem aufstrebenden Ast
Standard Sicherheitsfrage Suchfunktion per GET

Hi zusammen,

Ich habe nur eine kurze Sicherheitsfrage.

Ich habe ein Suchfeld auf meiner index.php und Sende dort mein Formular per GET ab.

Das Formular und die Auswertung erfolgt beides in der index.php

Filtern und Escapen tu ich wie folgt:

Index.php das Formular:

Code:
<form action="index.php" method="get">
    <div class="searchbar">
      <input type="text" name="search" class="searchfield input" id="searchfield" maxlength="200" alt="Suche... " value="Suche... " onclick="document.getElementById('searchfield').value=''; this.style.color = '#000';" />
             <input type="submit" id="submit" class="search-button" value="" />
    </div>
  </form>
PHP-Code:
<?php // Suche
      
if(isset($_GET["search"]) && !empty($_GET["search"])) {
        
    
$search preg_replace"/[^a-z0-9]/i"""$_GET["search"] );

$sql "SELECT * FROM ".$sqltab27." WHERE name LIKE '%".$db->escape($search)."%'";

usw ......
    
?>
Ich hab mal was von Tokens und Cross Site Script Attacken gelesen, ist das hier von Nöten ?
Starfox ist offline   Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 13.01.2012, 22:29  
php.de
Gast
 
Beiträge: n/a
Standard

Tokens gibts z. B. bei OAuth. Kurzfristige, eindeutige Keys, mit denen Berechtigungen erteilt werden. Wüsste nicht, warum man bei einem normalen Formular einen Token benötigen sollte.

Cross Site Script (XSS) muss man hingegen immer beachten. Lässt sich aber leicht dadurch ausschließen, dass man alle dynamischen Ausgaben in ein htmlentities oder htmlspecialchars packt. Trägt ein User in ein Textfeld ein Javascript ein, wird es dann nicht als JavaScript ausgeführt sondern nur als normaler Text ausgegeben.

Was bei dir fehlt, ist die Berücksichtigung von Sonderzeichen bei der Suche mit LIKE. _ und % müssen escapt werden. Dafür gibts addcslashes.

Geändert von php.de (13.01.2012 um 22:38 Uhr).
  Mit Zitat antworten
Alt 13.01.2012, 22:55  
moderatives Dielektrikum
 
Benutzerbild von nikosch
 
Registriert seit: 21.05.2008
Beiträge: 35.987
PHP-Kenntnisse:
Fortgeschritten
nikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunft
Standard

Zitat:
Wüsste nicht, warum man bei einem normalen Formular einen Token benötigen sollte.
Z.B. um einen doppelten Submit auszushließen.
Zitat:
if(isset($_GET["search"]) && !empty($_GET["search"])) {
empty impliziert isset, isset kann hier also weggelassen werden.
Zitat:
Was bei dir fehlt, ist die Berücksichtigung von Sonderzeichen bei der Suche mit LIKE. _ und % müssen escapt werden. Dafür gibts addcslashes.
Dann schau mal in die Zeile darüber.
__________________
--
One pixel is still too big. Please make it smaller. ASAP.

Initiative Mittelstand.
Die wichtigste Gestaltungsregel im Screendesign ist Pi mal Daumen des Arbeitgebers.
--
nikosch ist offline   Mit Zitat antworten
Alt 13.01.2012, 23:05  
php.de
Gast
 
Beiträge: n/a
Standard

Zitat:
Dann schau mal in die Zeile darüber.
Ahja. Na OK.
  Mit Zitat antworten
Alt 14.01.2012, 16:29  
Neuer Benutzer
 
Registriert seit: 29.11.2011
Beiträge: 4
PHP-Kenntnisse:
Anfänger
Starfox befindet sich auf einem aufstrebenden Ast
Standard

Zitat:
Cross Site Script (XSS) muss man hingegen immer beachten. Lässt sich aber leicht dadurch ausschließen, dass man alle dynamischen Ausgaben in ein htmlentities oder htmlspecialchars packt. Trägt ein User in ein Textfeld ein Javascript ein, wird es dann nicht als JavaScript ausgeführt sondern nur als normaler Text ausgegeben.
Das habe ich ja mit :

PHP-Code:
$search preg_replace"/[^a-z0-9]/i"""$_GET["search"] ); 
schon gemacht es werden ja nur Buchstaben und Zahlen vom Formular her zugelassen bzw alles andere eben gegen "" ersetzt.
Starfox ist offline   Mit Zitat antworten
Antwort


Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
Suchfunktion einbauen estebu PHP Tipps 2010 10 08.03.2010 23:13
Suchfunktion - nur bestimmte Seiten durchsuchen 54ch4 PHP Tipps 2009 5 02.10.2009 19:49
[Erledigt] Bitte um Hilfe bei erweiterter Suchfunktion ePole PHP Tipps 2009 20 13.08.2009 11:23
[Erledigt] Einfache Suchfunktion, bestimmte Seite nicht mit anzeigen. pixelprinzessin PHP Tipps 2009 6 31.07.2009 07:46
Suchfunktion via DropdownMenü & Javascript RostigerNagel PHP Tipps 2009 2 03.07.2009 12:09
Suchfunktion MySQL-Abfrage, meiste Treffer zuerst Felk PHP Tipps 2009 10 23.02.2009 22:42
[Erledigt] Suchfunktion &quot;Spezial&quot; errox PHP Tipps 2008 3 04.11.2008 12:41
Suchfunktion mit JavaScript snboy2007 JavaScript, Ajax und mehr 2 31.10.2007 13:38
Suchfunktion für die Homepage? Was muss der Anfänger wissen? PHP Tipps 2005-2 1 11.10.2005 18:39
suchfunktion PHP Tipps 2005-2 3 27.09.2005 16:39
Fehler bei Suchfunktion Matthias959 Off-Topic Diskussionen 4 17.09.2005 21:26
MySql error -- Suchfunktion mit mehreren Begriffen PHP Tipps 2005 1 12.04.2005 21:06
Suchfunktion PHP Tipps 2005 8 03.04.2005 15:52
Suchfunktion nur für EINE Seite ! HTML, Usability und Barrierefreiheit 2 24.03.2005 18:42


Alle Zeitangaben in WEZ +2. Es ist jetzt 18:51 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum