PHP-Logo
Druckansicht von http://www.php-homepage.de/manual/security.filesystem.nullbytes.php

PHP-Logo
[ Main Menue ]
Homepage
Downloads
Artikel
Scripts
Forum
PHP-Manual
Links
News
Freelancer
Bücher
RuDolF
Suche
Misc
Über diese Seite
Kontakt
Wunschzettel
MyGuestbook
*
[ Suche ]
*
[ Manual ]
*

Follow on Twitter - @phphomepage

RSS Feed blogoscoop
 Dateisystem - Sicherheit  Letztes Update:
18.05.2012
Datenbank - Sicherheit 

Probleme im Zusammenhang mit Nullbytes

Da PHP die Funktionen der C-Standardbibliothek für Dateisystemoperationen nutzt kann es Nullbytes in unerwarteter Weise verarbeiten. Da Nullbytes in C das Stringende festlegen werden Strings die solche enthalten nicht vollständig verarbeitet sondern nur bis zum ersten Auftreten eines Nullbytes. Das folgende Beispiel zeigt verwundbaren Programmkode der das Problem demonstriert:

Beispiel #1 Skript mit Nullbyte-Verwundbarkeit

<?php
  $file 
$_GET['file']; // "../../etc/passwd\0"
  
if (file_exists('/home/wwwrun/'.$file.'.php')) {
    
// file_exists gibt true zurück da /home/wwwrun/../../etc/passwd existiert
    
include '/home/wwwrun/'.$file.'.php';
    
// die Datei /etc/passwd wird eingebunden
  
}
?>

Daher sollte jede nicht vertrauenswürdige Zeichenkette, die in Dateisystemoperationen verwendet wird, ordentlich geprüft werden. Hier sehen Sie eine eine bessere Versiond des vorhergehenden Beispiels:

Beispiel #2 Korrekte Validierung der Eingabe

<?php
  $file 
$_GET['file'];
  
  
// Gestatte gültige Werte
  
switch ($file) {
    case 
'main':
    case 
'foo':
    case 
'bar':
      include 
'/home/wwwrun/include/'.$file.'.php';
      break;
    default:
      include 
'/home/wwwrun/include/main.php';
  }
?>
© Copyright 1999 - 2011 by Mark Kronsbein | Impressum | NutzungsbedingungenWeiterempfehlen | Seitenanfang
0.0044