Wer sollte einen PHP-Penetrationstest durchführen?
Die Zielgruppe für einen PHP Pentest ist jeder, der eine PHP-Anwendung entwickelt oder betreibt - speziell, wenn diese Anwendung beispielsweise Nutzerdaten verarbeitet oder gar im Bereich Versicherung oder Finanzen anzusiedeln ist. Je nach Branche und Anwendungsbereich können auch rechtliche Anforderungen dafür sorgen, dass ein PHP-Penetrationstest absolut notwendig ist.
Wenn Sie auf dieser Seite sind, wissen Sie vermutlich schon, dass Sie einen Pentest brauchen und ihre PHP-Sicherheit verbessern wollen. Allgemein sollte man sich anschauen, welche Daten in der eigenen Anwendung zu finden sind und feststellen, ob diese Daten für Angreifer interessant sein könnten. Auch die Frage, was man machen würde, wenn der Worst Case eintritt, beantwortet oft, ob man in IT-Sicherheit investieren sollte.
Wie viel kostet ein PHP-Penetrationstest?
Das hängt stark von Kompexität der Software und dem Scope ab. Kleinere PHP-Webanwendungen können problemlos ab 2.500 Euro getestet werden. Es gibt diverse Faktoren, die die Kosten nach oben aber auch stark nach unten treiben können. Wenn beispielsweise auf einen umfangreichen Testbericht verzichtet werden kann, lassen sich 15-20% sparen. Das optimale Vorgehen ist: Angebote einholen. Ohne konkret zu wissen, um was für eine PHP-Anwendung es sich handelt, kann niemand wirklich konkrete Kosten für so einen Pentest nennen.
Kleines Budget? Das ist kein Problem. Lassen Sie uns reden und den Scope so definieren, dass es Sinn macht und die Sicherheit Ihrer Anwendung signifikant verbessert wird. Eigentlich bekommen wir immer eine gute Lösung hin! Fragen kostet nichts!
"PHP hat einen schlechten Ruf - ich finde zu unrecht. PHP ist eine tolle Sprache, die nicht mehr wegzudenken ist. Egal, wie oft sie für tot erklärt wird."
Damian Strobel - Gründer von DSecured
PHP-Anwendungen haben oft viele Sicherheitslücken, lassen Sie uns alles finden und beheben.
Relevantes zum PHP-Penetrationstest
Pentest: Dienstleistungen
PHP-Pentest: Fokus auf Web-Frameworks - auch für API
Ein PHP-Penetrationstest ist im Grunde ein Web-Penetrationstest, der sich auf PHP-Anwendungen fokussiert. Um ehrlich zu sein, sehen wir im Jahr 2024 keine reinen PHP-Anwendungen. Vielmehr sind Webframeworks viel verbreiteter - zum Glück. Denn Webframeworks wie Laravel oder Symfony verhindern viele Sicherheitslücken, die in reinen PHP-Anwendungen auftreten können. Zwar darf man nie etwas ausschließen, aber eine SQL-Injection ist in einer Laravel-Anwendung deutlich schwerer zu finden als in einer reinen PHP-Anwendung.
Sogar im Bereich API-Entwicklung wird mittlerweile auf Webframeworks gesetzt. Primärer Grund ist, weil es viele Entwickler gibt und Themen wie Routing, Authentifizierung und Validierung bereits abgedeckt sind. Man muss das Rad nicht neu erfinden, das spart Zeit und damit Geld. DSecureds Fokus, wenn es um Frameworks geht, liegt klar auf Laravel und Symfony. Die Themenseiten findet man im Folgenden:
Laravel Pentest Symfony PentestWenn es um das Thema PHP geht, kommt man meist auch nicht um das Thema CMS rum. Bei CMS-Penetrationstests liegt der Fokus eher auf kleinen Komponenten, die z.B. von Freelancern oder Agenturen entwickelt wurden. Hierzu empfehlen wir unsere Schwerpunkte:
# WordPress Pentest # Typo3 Pentest # Drupal PentestEs wäre schade, wenn Hacker Ihre PHP-Anwendung hacken, Daten klauen und Schaden anrichten. Wir können kostengünstig helfen!
PHP-Sicherheitslücken: Was wir finden könnten
Schweregrad: Niedrig/Mittel
Klassische Funde mit niedrigem Schweregrad sind z.B. fehlende Sicherheitsheader oder die Möglichkeit Loginnamen zu enumerieren. Wenn es um den Schweregrad "mittel" geht, dann sind das z.B. fehlende CSRF-Token. Wichtig ist aber auch immer zu sagen, dass der Kontext wahnsinnig wichtig ist. Diese Funde können schnell zu großen Probleme werden.
Schweregrad: Hoch
Der hohe Schweregrad ist meistens mit einer hohen Auswirkung verbunden. Das Lesen von Dateien des Dateisystems (File Inclusions, Path Traversals) wäre so ein Beispiel. Auch das Auslesen von Datenbankinhalten (SQL Injection), könnte in diese Kategorie fallen. Auch hier ist Kontext wichtig, eine SQL-Injection kann ganz schnell kritisch werden.
Schweregrad: Kritisch
Kann man eigenen Code ausführen? Das wäre ein Beispiel für eine kritische Sicherheitslücke. Code Injection ist die Kategorie, vor der sich alle Sorgen machen. Ein Angreifer kann eigenen Code auf dem Server ausführen und damit oft den gesamten Server übernehmen. Er hat volle Kontrolle. In diese Kategorie fallen auch Schwachstellen, wie Deserialisierung (im Fall von PHP via unserialize).
PHP Penetrationstest: Blackbox oder Whitebox Test
Die absolute Mehrheit unsere PHP-Penetrationstests - speziell, wenn die Webanwendung komplexer ist - sind Blackbox-Tests. Das bedeutet, dass wir die Anwendung nicht kennen und uns wie ein Angreifer verhalten müssen. Oft ist es sogar so, dass wir nur wissen, dass es sich um eine PHP-Anwendung handelt. Der Vorteil hier ist, dass es ein recht realistisches Bild der Sicherheit der Anwendung gibt.
Das absolute Gegenteil ist im Grunde eine Analyse des Quellcodes. Das ist ein Whitebox-Test. Das wird seltener gefordert - primär, weil die Kosten oft deutlich höher als bei einem Blackbox-Pentest sind. Allerdings ist es so, dass DSecured einige Mitarbeiter hat, die sowohl PHP-Entwickler als auch Penetrationstester sind - und das seit Jahren. Ein Whitebox-Test würde hier zwar teurer sein, aber mehr Ergebnisse hervorbringen.
Einige Unternehmen, denen wir bisher helfen konnten
Weitere Fragen samt Antworten zum Thema
"PHP Penetrationstest"
Wie lange dauert ein typischer PHP Penetrationstest?
Ein durchschnittlicher PHP Penetrationstest wird normal in 1-3 Wochen abgeschlossen. Dies variiert jedoch je nach Komplexität und Umfang der zu testenden Systeme.
Welche Art von Sicherheitslücken kann ein PHP Penetrationstest aufdecken?
Der Fokus liegt hier meist auf Web-Sicherheitslücken: IDOR, SQL Injection, RCE, File Path Traversals und ähnliches. Business-Logic-Fehler und andere Schwachstellen können ebenfalls identifiziert werden.
Wie bereite ich mein Team auf einen bevorstehenden PHP Penetrationstest vor?
Wir brauchen Zugang zu einer Demo-Version Ihrer Anwendung. Am besten mit realistischen Daten - das inkludiert natürlich auch Nutzer und Rollen. Dokumentationen und Architekturdiagramme sind ebenfalls hilfreich.
Ist die Umgebung während eines PHP Penetrationstests sicher?
Wir sehen zu, dass wir ausschließlich auf Testumgebungen arbeiten. Diese sollten von Produktionsumgebungen getrennt sein.
Gibt es eine bestimmte Phase der Entwicklung, in der PHP-Sicherheitsbewertungen am besten durchgeführt werden sollten?
Ein gewisser Teil sollte während des CI/CD Prozesses automatisiert durchgeführt werden. Ein guter Punkt, um Penetrationstests durchzuführen, ist nach der Implementierung und vor dem Go-Live.
Welches Endresultat kann ich von einem PHP Pentest erwarten?
Das Ergebnis ist immer ein finaler PDF-Bericht, der eine Zusammenfassung für die Führungsetage sowie einen technischen Teil enthält. Letzteres ist dazu gedacht, dass Ihr Entwicklerteam die gefundenen Schwachstellen beheben kann.
Welche weiteren Elemente werden zusätzlich zu PHP in einem umfassenden Pentest abgedeckt?
Meist haben wir es hier mit Webanwendungen zu tun. Der Webserver sowie die Datenbank spielen im Scope eine entscheidende Rolle. Auch die Kommunikation zwischen den Systemen wird überprüft.
Gibt es Standards, die man bei PHP-Sicherheitstests befolgt?
Ja, wir halten uns an anerkannte Industriestandards und Frameworks wie OWASP sowie dem IS-Pentest-Standard des BSI, um Ihnen eine methodische und gründliche Überprüfung zu bieten.
Wie oft sollten PHP-Penetrationstests durchgeführt werden?
Die Häufigkeit sollte sich an Ihrem Entwicklungszyklus orientieren, aber in der Regel gewährleisten erneute Tests alle 12 Monate oder nach wesentlichen Änderungen eine gleichbleibende Sicherheit.
PHP Penetrationstest anfragen