PHP Portal » PHP Handbuch » Probleme im Zusammenhang mit Nullbytes

Werbung

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:

PHP Code
1
2
3
4
5
6
$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:

PHP Code
1
2
3
4
5
6
7
8
9
10
11
12
$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'; }