php-resource



Zurück   PHP-Scripte PHP-Tutorials PHP-Jobs und vieles mehr > Entwicklung > PHP Developer Forum
 

Login

 
eingeloggt bleiben
star Jetzt registrieren   star Passwort vergessen
 

 

 


PHP Developer Forum Hier habt ihr die Möglichkeit, eure Skriptprobleme mit anderen Anwendern zu diskutieren. Seid so fair und beantwortet auch Fragen von anderen Anwendern. Dieses Forum ist sowohl für ANFÄNGER als auch für PHP-Profis! Fragen zu Laravel, YII oder anderen PHP-Frameworks.

Antwort
 
LinkBack Themen-Optionen Thema bewerten
  #1 (permalink)  
Alt 05-09-2003, 23:49
Novan
 Registrierter Benutzer
Links : Onlinestatus : Novan ist offline
Registriert seit: Feb 2003
Beiträge: 31
Novan ist zur Zeit noch ein unbeschriebenes Blatt
Novan eine Nachricht über ICQ schicken
Question Regulärer Ausdruck um Scriptbereiche zu löschen

Hi,
ich habe mal wieder nen Problem mit den ollen regulären Ausdrücken. Am Anfang denke ich immer "Das is doch bestimmt ganz leicht...reihste die Sachen aneinander und fertig" nur macht er wie eigentlich immer nicht.

Also ich habe so einen Browser WYSIWYG Editor in meine Homepage eingebaut und damit kann man dann einige Seiten erstellen und einbinden.
Da man so einen Editor aber auch dazu mißbrauchen kann PHP oder Javaskripte zu Coden will ich nach dem Absenden des Inhalts des Editors prüfen, ob solche Sachen dadrin sind und diese rauslöschen.

Gedacht habe ich es mir so (funktioniert aber nicht)
PHP-Code:
preg_replace('/(<script.+<\/script>)|(<\?php.+\?>)|(<\?.*\?>)/i','',$text); 
Kann mir wer helfen wie der lauten müßte damit Javaskripte und PHP Skripte gelöscht werden?
Vielleicht hat ja auch einer einen Ausdruck irgendwo rumfliegen der genau für diese Thematik gut ist und auch anderen Müll an den ich jetzt noch nicht gedacht habe rauskillt.

PS: Habe gerade gesehen das Forum zeigt einige \ im PHP-Code nicht an
daher pflichte ich bei, dass <? escaped ist und ?> auch jeweils. Ausserdem das </script ist auch noch escaped.

PS2: Hups falsches Forum...wie kann man seinen Beitrag löschen und woanders neu posten...?
Wenn ihn wer verschieben will nur zu

Geändert von Novan (05-09-2003 um 23:53 Uhr)
Mit Zitat antworten
freelancermap.de - IT Projektvermittlung für Selbständige und Freiberufler
  #2 (permalink)  
Alt 06-09-2003, 00:15
TobiaZ
  Moderator
Links : Onlinestatus : TobiaZ ist offline
Registriert seit: Jan 2001
Ort: MUC und MGL, Germany
Beiträge: 34.421
Blog-Einträge: 1
TobiaZ befindet sich auf einem aufstrebenden Ast
Standard

preg_replace('/((\<script(.+)\<\/script\> )|(\<\?php(.+)\?\> )|(\<\(.*)?\>))/i','',$text);

mal ganz dumm geraten.
__________________
ERST LESEN: Unsere Regeln. | Ich hab schon Pferde kotzen sehn!

READ THIS: Strings richtig trennen/verbinden | JOINs, das leidige Thema | Wegwerf E-Mail Adressen

Ich werde keinen privaten 1:1 Support leisten, außer ich biete ihn ausdrücklich an.

Wenn man sich selbst als "Noob" bezeichnet, sollte man die Finger davon lassen.
Wenn man gewillt ist daran etwas zu ändern, lernt man Grundlagen!
Mit Zitat antworten
  #3 (permalink)  
Alt 06-09-2003, 13:23
Novan
 Registrierter Benutzer
Links : Onlinestatus : Novan ist offline
Registriert seit: Feb 2003
Beiträge: 31
Novan ist zur Zeit noch ein unbeschriebenes Blatt
Novan eine Nachricht über ICQ schicken
Standard

Hmm,
ich hab es nun geschafft die PHP Sachen aus dem Code zu löschen aber Javascript macht er immer noch nicht

PHP-Code:
$text preg_replace('/(\<\?php[^\?\>]*\?\>)|(\<\?[^\?\>]*\?\>)|(<script[^<\/script>]*<\/script>)/i','',stripslashes($HTTP_POST_VARS['ta'])); 
PS: Ist wie immer alles richtig escaped. Wir im Forum hier bloß nicht dargestellt.
Mit Zitat antworten
  #4 (permalink)  
Alt 06-09-2003, 13:41
TobiaZ
  Moderator
Links : Onlinestatus : TobiaZ ist offline
Registriert seit: Jan 2001
Ort: MUC und MGL, Germany
Beiträge: 34.421
Blog-Einträge: 1
TobiaZ befindet sich auf einem aufstrebenden Ast
Standard

dann poste mal im nomalen text, bzw. code
__________________
ERST LESEN: Unsere Regeln. | Ich hab schon Pferde kotzen sehn!

READ THIS: Strings richtig trennen/verbinden | JOINs, das leidige Thema | Wegwerf E-Mail Adressen

Ich werde keinen privaten 1:1 Support leisten, außer ich biete ihn ausdrücklich an.

Wenn man sich selbst als "Noob" bezeichnet, sollte man die Finger davon lassen.
Wenn man gewillt ist daran etwas zu ändern, lernt man Grundlagen!
Mit Zitat antworten
  #5 (permalink)  
Alt 06-09-2003, 13:47
Novan
 Registrierter Benutzer
Links : Onlinestatus : Novan ist offline
Registriert seit: Feb 2003
Beiträge: 31
Novan ist zur Zeit noch ein unbeschriebenes Blatt
Novan eine Nachricht über ICQ schicken
Standard

Es ist zwar nur eine Testeingabe aber dort sind halt alle relevanten dinger drin die rausgelöscht werden sollen
PHP-Code:
Huhu das ist ein Test<br><br>
<?php
print 'f';
?>

Noch ein Test

<?
print 'huhu';
?>

Und nun noch Javascript

<script language="JavaScript">
<!--
alert('JavaScript');
//-->
</script>
Am Ende soll dann nur noch da stehen:
PHP-Code:
Huhu das ist ein Test<br><br>
Noch ein Test
Und nun noch Javascript 
Alles andere soll rausgelöscht werden.
Mit Zitat antworten
  #6 (permalink)  
Alt 06-09-2003, 13:58
TobiaZ
  Moderator
Links : Onlinestatus : TobiaZ ist offline
Registriert seit: Jan 2001
Ort: MUC und MGL, Germany
Beiträge: 34.421
Blog-Einträge: 1
TobiaZ befindet sich auf einem aufstrebenden Ast
Standard

ich mein dir regex
__________________
ERST LESEN: Unsere Regeln. | Ich hab schon Pferde kotzen sehn!

READ THIS: Strings richtig trennen/verbinden | JOINs, das leidige Thema | Wegwerf E-Mail Adressen

Ich werde keinen privaten 1:1 Support leisten, außer ich biete ihn ausdrücklich an.

Wenn man sich selbst als "Noob" bezeichnet, sollte man die Finger davon lassen.
Wenn man gewillt ist daran etwas zu ändern, lernt man Grundlagen!
Mit Zitat antworten
  #7 (permalink)  
Alt 06-09-2003, 14:01
Novan
 Registrierter Benutzer
Links : Onlinestatus : Novan ist offline
Registriert seit: Feb 2003
Beiträge: 31
Novan ist zur Zeit noch ein unbeschriebenes Blatt
Novan eine Nachricht über ICQ schicken
Standard

PHP-Code:
'/(<?php[^?>]*?> )|(<?[^?>]*?> )|(<script[^</script>]*</script> )/i'
Davon funktionieren die ersten beiden Abschnitte, die sich mit php beschäftigen nur der Teil
PHP-Code:
(<script[^</script>]*</script>) 
der ja Javascriptpassagen rauslöschen soll funktioniert nicht.
Mit Zitat antworten
  #8 (permalink)  
Alt 06-09-2003, 14:02
TobiaZ
  Moderator
Links : Onlinestatus : TobiaZ ist offline
Registriert seit: Jan 2001
Ort: MUC und MGL, Germany
Beiträge: 34.421
Blog-Einträge: 1
TobiaZ befindet sich auf einem aufstrebenden Ast
Standard

du solltest mal als text/code posten, wegen den escapes-
__________________
ERST LESEN: Unsere Regeln. | Ich hab schon Pferde kotzen sehn!

READ THIS: Strings richtig trennen/verbinden | JOINs, das leidige Thema | Wegwerf E-Mail Adressen

Ich werde keinen privaten 1:1 Support leisten, außer ich biete ihn ausdrücklich an.

Wenn man sich selbst als "Noob" bezeichnet, sollte man die Finger davon lassen.
Wenn man gewillt ist daran etwas zu ändern, lernt man Grundlagen!
Mit Zitat antworten
  #9 (permalink)  
Alt 06-09-2003, 14:05
Novan
 Registrierter Benutzer
Links : Onlinestatus : Novan ist offline
Registriert seit: Feb 2003
Beiträge: 31
Novan ist zur Zeit noch ein unbeschriebenes Blatt
Novan eine Nachricht über ICQ schicken
Standard

//
// Prüfung ob Skriptinhalte im Quelltext exestieren denn diese sind verboten.
//
$text = preg_replace('/(\<\?php[^\?\>]*\?\>)|(\<\?[^\?\>]*\?\>)|(<script[^<\/script>]*<\/script>)/i','',stripslashes($HTTP_POST_VARS['ta']));
//
// Speichern der Daten
//
$sql = 'UPDATE '.TT_TABLE.' SET
titel = "'.addslashes($HTTP_POST_VARS['titel']).'",
text = "'.$text.'"
WHERE tips_tricks_id = '.$edit_entry;
Mit Zitat antworten
  #10 (permalink)  
Alt 06-09-2003, 14:24
mrhappiness
 PHP Guru
Links : Onlinestatus : mrhappiness ist offline
Registriert seit: Oct 2002
Beiträge: 14.890
mrhappiness ist zur Zeit noch ein unbeschriebenes Blatt
mrhappiness eine Nachricht über AIM schicken mrhappiness eine Nachricht über Yahoo! schicken
Standard

ich versteh deinen ausdruck nich, wozu [^<\/script>]* ?

probier mal
Code:
$text='Test1
<?php print "f"; ?>
Test2
<? print "huhu"; ?>
Test3
< script language="JavaScript">
<!--
alert("JavaScript 1");
//-->
</script>
Test4
< script language="JavaScript">
<!--
alert("JavaScript 2");
//-->
</script>
Test5
<?php
echo "Na sowas";
?>
Test6';
$pattern='%(<[ ]*\?.*\?[ ]*>)|(<[ ]*script[ ]*(.*)>.*<[ ]*/[ ]*script[ ]*>)%siU';
$text_bereinigt=preg_replace($pattern,'',$text);
echo '<xmp>'.$text.'</xmp><hr /><xmp>'.$text_bereinigt.'</xmp>';
mehr als die fragezeichen sind nich escaped
__________________
Ich denke, also bin ich. - Einige sind trotzdem...
Mit Zitat antworten
  #11 (permalink)  
Alt 06-09-2003, 14:39
Novan
 Registrierter Benutzer
Links : Onlinestatus : Novan ist offline
Registriert seit: Feb 2003
Beiträge: 31
Novan ist zur Zeit noch ein unbeschriebenes Blatt
Novan eine Nachricht über ICQ schicken
Standard

Also ich habe dein Ausdruck mal probiert aber der filtert gar nichts raus weder phpcode noch javascriptcode

Also das (<script[^<\/script>]*<\/script>) soll alle Abschnitte finden, die mit <script anfangen und dannach dürfen unbegrenzt viele Zeichen kommen bloß kein </script> und das Ende soll </script> sein.

Ich habe mir das so gedacht, da es bei den beiden Abschnitten davor ja auch gefunzt hat. Also dachte ich es mir so das ich es einfach kopiere und die Zeichen tausche.
Mit Zitat antworten
  #12 (permalink)  
Alt 06-09-2003, 14:45
mrhappiness
 PHP Guru
Links : Onlinestatus : mrhappiness ist offline
Registriert seit: Oct 2002
Beiträge: 14.890
mrhappiness ist zur Zeit noch ein unbeschriebenes Blatt
mrhappiness eine Nachricht über AIM schicken mrhappiness eine Nachricht über Yahoo! schicken
Standard

bei mir geht's, und damit du's mir glaubst hier ein beweis
__________________
Ich denke, also bin ich. - Einige sind trotzdem...
Mit Zitat antworten
  #13 (permalink)  
Alt 06-09-2003, 14:56
Novan
 Registrierter Benutzer
Links : Onlinestatus : Novan ist offline
Registriert seit: Feb 2003
Beiträge: 31
Novan ist zur Zeit noch ein unbeschriebenes Blatt
Novan eine Nachricht über ICQ schicken
Standard

Danke....
habe das wohl etwas überstürzt getestet es läuft doch

Leider verstehe ich den Ausdruck nicht so wirklich. Sieht ziemlich kuriose aus. Wenn du noch Lust hast kannst du den ja mal für mich erklären.
Mit Zitat antworten
  #14 (permalink)  
Alt 06-09-2003, 15:01
mrhappiness
 PHP Guru
Links : Onlinestatus : mrhappiness ist offline
Registriert seit: Oct 2002
Beiträge: 14.890
mrhappiness ist zur Zeit noch ein unbeschriebenes Blatt
mrhappiness eine Nachricht über AIM schicken mrhappiness eine Nachricht über Yahoo! schicken
Standard

denk dir die [ ]* mal weg, die verhindern nur dass jemand statt <script> einfach < script> schreibt

dann hast du nur noch %(<\?.*\?>)|(<script(.*)>.*</script)%siU

das sollte klar sein oder?
__________________
Ich denke, also bin ich. - Einige sind trotzdem...
Mit Zitat antworten
  #15 (permalink)  
Alt 06-09-2003, 15:08
Novan
 Registrierter Benutzer
Links : Onlinestatus : Novan ist offline
Registriert seit: Feb 2003
Beiträge: 31
Novan ist zur Zeit noch ein unbeschriebenes Blatt
Novan eine Nachricht über ICQ schicken
Standard

hmm jo sieht schon viel einleuchtender aus

wie sieht das mit
ASP Pssagen aus? Intressieren mein Server zwar nicht weil der kein ASP unterstützt aber nur aus neugiert.
und was macht das % ist das gleich einem / für die modifier?
Mit Zitat antworten
Antwort

Lesezeichen


Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
 

Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre 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


PHP News

PHP Marktplatz-Software
PHP Marktplatz-SoftwareEs hat sich viel getan! Die neue Version 7.5.9 unserer PHP Marktplatz-Software ebiz-trader steht ab sofort zur Verfügung.

28.10.2019 | Berni

Die RIGID-FLEX-Technologie
Die RIGID-FLEX-TechnologieDie sogenannte "Flexible Elektronik" , oftmals auch als "Flexible Schaltungen" bezeichnet, ist eine zeitgemäße Technologie zum Montieren von elektronischen Schaltungen.

06.12.2018 | Berni


 

Aktuelle PHP Scripte

SMT

Server Monitoring & Management Tool Das SMT wurde von einem Administrator für Administratoren entwickelt, es vereinfacht den Alltag in der klassischen Administration und Verwaltung. Mit dem SMT kannst Du alle Deine Server & Dienste verwalten und überwach

04.09.2020 palle_1977 | Kategorie: PHP
numaeks Web-Farbmixer

Die RGB-Farben lassen sich hier auf unterschiedliche Weise mischen. Zur Einstellung werden auch die Dreh- und Schieberegler mit Canvas verwendet. Gespeichert werden die Farben in einem Cookie.

04.09.2020 numaek | Kategorie: JAVASCRIPT/ Tools
phplinX-Erotikportal 4 ansehen phplinX-Erotikportal 4

Erweiterbares Portal speziell für Erotik mit den Modulen Webkatalog, Bannermanagement und Kleinanzeigenmarkt. Sämtliche Module können über einen einzigen Adminbereich verwaltet werden.

18.06.2020 Cosinus14 | Kategorie: PHP/ Anzeigenmarkt
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 09:32 Uhr.