Montag, 13. September 2010

PHP

OpenX Hotfix für Sicherheitsproblem

In OpenX ist eine Sicherheitslücke enthalten, mit der man Dateien auf den Webserver hochladen kann.

Die Lücke ist in der Datei ofc_upload_image.php. Die Date ofc_upload_image.php gehört zum Diagramm-Modul.

Mit kann man Dateien hochladen. Wie das implementiert ist, kann man hier sehen:

Download Code!

  1. if (!file_exists($default_path)) mkdir($default_path, 0777, true);
  2.  
  3. // full path to the saved image including filename //
  4. $destination = $default_path . basename( $_GET[ 'name' ] );
  5.  
  6. echo 'Saving your image to: '. $destination;
  7.  
  8. $jfh = fopen($destination, 'w') or die("can't open file");
  9. fwrite($jfh, $GLOBALS['HTTP_RAW_POST_DATA']);
  10. fclose($jfh);
  11.  

Das Problem liegt in einmal in der Zeile 4, dort wird eine GET-Parameter ungeprüft in einen Verzeichnispfad gewandelt.

Und das andere ist die Zeile 9, hier kommt der Payload rein...

Beheben lässt sich das Ganze durch löschen - so ist die allgemeine Antwort, denn ein Patch dafür gibt es nicht :-(

Hotfix

Naja damit ihr nicht allein im Regen damit stehen müsst, hier ein echter Hotfix - und dazu noch ungeprüft :-)

Der Patch sollte verhindern, dass eine Datei hochgeladen werden kann, welche sich zum Ausführen von Code missbrauchen lässt.

Ziemlich drity, sollte aber im ersten Moment ausreichen:

Download Code!

  1. if (!file_exists($default_path)) mkdir($default_path, 0777, true);
  2. //Hotfix Mr. Foo - untested, be carefull
  3. if(preg_match('#\.(?:php(?:\d)*|phtml)(?:$|\.|\?| )#im', $_GET['name')) {
  4.   die('You are bad...');
  5. }
  6. // full path to the saved image including filename //
  7.  
  8. $destination = $default_path . basename( $_GET[ 'name' ] );
  9.  
  10. echo 'Saving your image to: '. $destination;
  11.  
  12. $jfh = fopen($destination, 'w') or die("can't open file");
  13. fwrite($jfh, $GLOBALS['HTTP_RAW_POST_DATA']);
  14. fclose($jfh);
Bewertung: 3 von 5, 2 Stimme(n) 986 Klicks
Patch, PHP
Von Mr.Foo in PHP am 13.09.10@23:30 Uhr

Trackbacks
Trackback für spezifische URI dieses Eintrags

Keine Trackbacks

0 Kommentare
Ansicht der Kommentare: (Linear | Verschachtelt)

Noch keine Kommentare


Kommentar schreiben

Umschließende Sterne heben ein Wort hervor (*wort*), per _wort_ kann ein Wort unterstrichen werden.
Standard-Text Smilies wie :-) und ;-) werden zu Bildern konvertiert.
Die angegebene E-Mail-Adresse wird nicht dargestellt, sondern nur für eventuelle Benachrichtigungen verwendet.
Sie können [geshi lang=LANG][/lang] Tags verwenden um Quellcode abhängig von der gewählten Programmiersprache einzubinden
 
 

Mr. Foo

OpenX Hotfix für Sicherheitsproblem

  • Homepage

Suche

Kategorien

  • Android (2)
  • C-Sharp (4)
  • Datenbank (30)
  • Delphi (2)
  • Entwicklung (36)
  • Flash (5)
  • Games (10)
  • Gutscheine (4)
  • Hardware (14)
  • HTML CSS (16)
  • Internet (88)
  • Java (32)
  • Javascript (24)
  • Linkdump (9)
  • Linux (102)
  • Low-Level (10)
  • Lua (8)
  • Musik (9)
  • Netzwerk (25)
  • New World Order (109)
  • Perl (3)
  • PHP (130)
  • Magento (5)
  • Symfony (3)
  • Zend Framework (7)
  • Probleme und Lösungen (26)
  • Python (22)
  • Ressourcen (23)
  • Sicherheit (91)
  • Software (60)
  • Sonstiges (47)
  • Own Stuff (48)
  • Spass (46)
  • Technik / Wissenschaft (4)
  • Tips (15)
  • Weisheiten (17)
  • Windows (23)
  • Wort des Tages (15)


Alle Kategorien

Archive

  • Mai 2012
  • April 2012
  • März 2012
  • Das Neueste ...
  • Älteres ...

Abonnieren lohnt sich!

  • XML RSS 2.0 feed
  • ATOM/XML ATOM 1.0 feed
  • XML RSS 2.0 Kommentare

Tagcloud

Datenbank Entwicklung Internet Java Javascript Linux Lösung Netzwerk News New World Order PHP Problem Probleme und Lösungen Sicherheit Software Sonstiges Spass Tipp Update Windows

Beliebte Einträge

  • Magento ist scheisse (197)
  • Plugin-container.exe deaktivieren (107)
  • BWin Betrug und Abzocke bei Minigames? (65)
  • C compiler cannot create executables unter Debian (53)
  • Scheiss Linux - USB-Platte viel zu langsam (wenns mal funktioniert) (43)
  • Sicheres Kontaktformular mit PHP - Spam verhindern (37)
  • UML-Diagramme aus Java-Klassen generieren – Java2UML (28)
  • Es konnte keine TCP/IP-Verbindung mit dem Host hergestellt werden (28)
  • Option Bug im Internet Explorer bei Nutzung von innerHTML und Javascript (24)
  • Zend Studio - Javaw.exe lastet die CPU aus (24)

Kommentare

Hugo zu BWin Betrug und Abzocke bei Minigames?
So, 20.05.2012 12:25
ich habe mich gestern auf BWIN reg [...]
Ubuntu 12.04 zu The assembly mscorlib.dll was not found or could not be loaded.
Fr, 18.05.2012 17:11
Hat bei mir leider nicht geklappt. [...]
Oliver Riske zu Es konnte keine TCP/IP-Verbindung mit dem Host hergestellt werden
Di, 15.05.2012 20:38
Super Danke!
anon zu BWin Betrug und Abzocke bei Minigames?
Sa, 05.05.2012 18:43
ihr scheiss betrüger
Jürgen zu Unable to elevate error:1814 VLC Problem
Mi, 02.05.2012 16:54
So einfach ist es bei mir jedenfal [...]
 

Kontakt/Informationen