
코더 컨커 시큐리티 OWASP Top 10 API 시리즈 - 보안 기능 비활성화/디버그 기능 활성화/부적절한 권한
Während die meisten Schwachstellen in dieser Liste ziemlich spezifisch für APIs sind, ist das Problem der deaktivierten Sicherheitsfunktionen/aktivierten Debug-Funktionen/unzulässigen Berechtigungen eines, das überall auftreten kann. Es ist wahrscheinlich etwas häufiger in APIs anzutreffen, aber Angreifer werden oft versuchen, ungepatchte Schwachstellen und ungeschützte Dateien oder Verzeichnisse irgendwo in einem Netzwerk zu finden. Wenn sie auf eine API stoßen, bei der das Debugging aktiviert oder die Sicherheitsfunktionen deaktiviert sind, macht das ihre schändliche Arbeit nur ein wenig einfacher. Schlimmer noch, es gibt automatisierte Tools, um Sicherheitsfehlkonfigurationen zu erkennen und auszunutzen. Wenn Sie diese also in Ihrer Umgebung haben, besteht eine gute Chance, dass sie ausgenutzt werden, weshalb diese Schwachstelle es auf die OWASP-Liste der gefährlichen API-Schwachstellen geschafft hat.
Bevor wir mit dem Spaß beginnen, sehen Sie, ob Sie diese Debug-Herausforderung lösen können:
Wie schleicht sich der Fehler deaktivierte Sicherheitsfunktionen/aktivierte Debug-Funktionen/unzulässige Berechtigungen in eine API ein?
Um zu sehen, wie dieser mehrdimensionale API-Fehler in die Netzwerke gelangt, müssen wir ihn in seine Bestandteile zerlegen. Beginnen wir mit dem Problem der aktivierten Debugging-Funktionen. Debugging ist ein nützliches Werkzeug, das Entwicklern hilft, herauszufinden, warum Anwendungen nicht richtig funktionieren oder Fehler machen. Wenn Debugging aktiviert ist, werden bei Fehlern und Ausnahmen detaillierte Fehlerseiten generiert, so dass Entwickler sehen können, was schief gelaufen ist und Probleme beheben können. Es ist völlig in Ordnung, diese Funktion zu aktivieren, während sich eine Anwendung noch in der Entwicklung befindet.
Es gibt jedoch einen Grund, warum die meisten Frameworks mit Warnungen über die Ausführung des Debug-Modus in einer Produktionsumgebung kommen, wahrscheinlich direkt im Code, wo das Debugging aktiviert ist. Zum Beispiel:
# SICHERHEITSWARNUNG: nicht mit eingeschaltetem Debug in der Produktion ausführen!
DEBUG = True
In diesem Beispiel wurde das Debugging aktiviert. Die Django-Anwendung generiert detaillierte Fehlerseiten, wenn eine Ausnahme ausgelöst wird. Wenn dies in einer Produktionsumgebung geschieht, hätte ein Angreifer Zugriff auf diese Fehlerseiten, die Metadateninformationen über die Umgebung enthalten. Obwohl bei den meisten Frameworks das Debugging standardmäßig ausgeschaltet ist, vergisst man leicht, es wieder auszuschalten, wenn es während eines langen Entwicklungsprozesses aktiviert wurde. Wenn die Anwendung dann in eine Produktionsumgebung übergeht, bietet sie Angreifern viele Informationen darüber, wie sie eine Anwendung oder sogar einen ganzen Server oder ein Netzwerk kompromittieren können.
Während das Aktivieren des Debug-Modus meist ein eigenständiges Problem darstellt, wirken die Schwachstellen mit falschen Berechtigungen und deaktivierten Sicherheitsfunktionen oft zusammen. In einem realen Szenario, das von OWASP zur Verfügung gestellt wurde, verwendete ein Angreifer beispielsweise eine Suchmaschine, um eine Datenbank zu finden, die versehentlich mit dem Internet verbunden war. Da das beliebte Datenbankmanagementsystem seine Standardkonfiguration verwendete, war die Authentifizierung deaktiviert. Durch die Kombination der falschen Berechtigungen und der deaktivierten Sicherheitsfunktionen erlangte der Angreifer somit Zugriff auf Millionen von Datensätzen mit PII, persönlichen Einstellungen und Authentifizierungsdaten.
Beseitigung der deaktivierten Sicherheitsfunktionen/aktivierten Debug-Funktionen/unzulässigen Berechtigungsschwachstellen
Wahrscheinlich müssen Sie bei der Beseitigung dieser Schwachstelle einen zweigleisigen Ansatz wählen. Um den aktivierten Debug-Teil des Problems zu beseitigen, fügen Sie einfach eine Prüfung in den Entwicklungsprozess ein, um sicherzustellen, dass das Debugging deaktiviert wird, bevor eine API oder Anwendung in die Produktionsumgebung verschoben wird. In unserem Beispiel würde der richtige Befehl dazu folgendermaßen lauten:
# SICHERHEITSWARNUNG: nicht mit eingeschaltetem Debug in der Produktion ausführen!
DEBUG = False
Jetzt werden die Debug-Funktionen in der Django-Anwendung deaktiviert, indem das DEBUG-Flag auf False konfiguriert wird. Als Reaktion auf Fehler werden keine Fehlerseiten generiert. Wenn ein Angreifer dennoch Zugriff auf Fehlerseiten erhält, enthalten diese keine nützlichen Metadaten und stellen kein Risiko für die Anwendung dar.
Die Beseitigung von deaktivierten Sicherheitsfunktionen und Schwachstellen durch falsche Berechtigungen ist etwas schwieriger, da sie eine Vielzahl von spezifischen Schwachstellen umfassen können. Der beste Weg, sie zu stoppen, ist die Entwicklung eines standardisierten und wiederholbaren Prozesses, der eine schnelle und einfache Bereitstellung von gesperrten Assets in der Produktionsumgebung ermöglicht.
Selbst dann sollten Sie einen Prozess erstellen, bei dem Orchestrierungsdateien, API-Komponenten und Cloud-Dienste wie Amazon S3-Bucket-Berechtigungen ständig überprüft und aktualisiert werden. Bei dieser Überprüfung sollte auch die Gesamtwirksamkeit der Sicherheitseinstellungen in der gesamten Umgebung im Laufe der Zeit bewertet werden, um sicherzustellen, dass das Unternehmen seine API-Sicherheit stets verbessert.
Schauen Sie sich die Secure Code Warrior Blog-Seiten, um mehr über diese Schwachstelle zu erfahren und zu erfahren, wie Sie Ihr Unternehmen und Ihre Kunden vor den Auswirkungen anderer Sicherheitslücken schützen können. Sie können auch eine Demo der Schulungsplattform Secure Code Warrior ausprobieren, um alle Ihre Cybersecurity-Kenntnisse zu schärfen und auf dem neuesten Stand zu halten.


API에서 조금 더 널리 퍼져 있을 가능성이 높지만 공격자는 네트워크 어디서나 패치가 적용되지 않은 결함이나 보호되지 않은 파일 또는 디렉터리를 찾으려고 시도하는 경우가 많습니다.디버깅이 활성화되거나 보안 기능이 비활성화된 API를 발견하면 악의적인 작업이 조금 더 쉬워집니다.
Matias Madou, Ph.D., ist Sicherheitsexperte, Forscher, CTO und Mitbegründer von Secure Code Warrior. Matias promovierte an der Universität Gent im Bereich Anwendungssicherheit und konzentrierte sich dabei auf statische Analyselösungen. Später wechselte er zu Fortify in den USA, wo er erkannte, dass es nicht ausreicht, nur Codeprobleme zu erkennen, ohne den Entwicklern beim Schreiben von sicherem Code zu helfen. Dies inspirierte ihn dazu, Produkte zu entwickeln, die Entwickler unterstützen, den Aufwand für die Sicherheit verringern und die Erwartungen der Kunden übertreffen. Wenn er nicht an seinem Schreibtisch im Team Awesome sitzt, steht er gerne auf der Bühne und hält Vorträge auf Konferenzen wie der RSA Conference, BlackHat und DefCon.

Secure Code Warrior ist für Unternehmen da, um den Code während des gesamten Softwareentwicklungszyklus zu schützen und eine Kultur zu schaffen, in der Cybersicherheit oberste Priorität hat. Unabhängig davon, ob Sie AppSec-Manager, Entwickler, CISO oder in einem anderen Bereich der Sicherheit tätig sind, können wir Ihnen dabei helfen, die Risiken zu reduzieren, die mit unsicherem Code verbunden sind.
Demo-Termin vereinbarenMatias Madou, Ph.D., ist Sicherheitsexperte, Forscher, CTO und Mitbegründer von Secure Code Warrior. Matias promovierte an der Universität Gent im Bereich Anwendungssicherheit und konzentrierte sich dabei auf statische Analyselösungen. Später wechselte er zu Fortify in den USA, wo er erkannte, dass es nicht ausreicht, nur Codeprobleme zu erkennen, ohne den Entwicklern beim Schreiben von sicherem Code zu helfen. Dies inspirierte ihn dazu, Produkte zu entwickeln, die Entwickler unterstützen, den Aufwand für die Sicherheit verringern und die Erwartungen der Kunden übertreffen. Wenn er nicht an seinem Schreibtisch im Team Awesome sitzt, steht er gerne auf der Bühne und hält Vorträge auf Konferenzen wie der RSA Conference, BlackHat und DefCon.
Matias ist ein Forscher und Entwickler mit mehr als 15 Jahren praktischer Erfahrung im Bereich der Softwaresicherheit. Er hat Lösungen für Unternehmen wie Fortify Software und sein eigenes Unternehmen Sensei Security entwickelt. Im Laufe seiner Karriere hat Matias mehrere Forschungsprojekte zur Anwendungssicherheit geleitet, die zu kommerziellen Produkten geführt haben, und kann auf über 10 Patente verweisen. Wenn er nicht am Schreibtisch sitzt, ist Matias als Ausbilder für fortgeschrittene Anwendungssicherheitstrainings courses tätig und hält regelmäßig Vorträge auf globalen Konferenzen wie RSA Conference, Black Hat, DefCon, BSIMM, OWASP AppSec und BruCon.
Matias hat einen Doktortitel in Computertechnik von der Universität Gent, wo er die Sicherheit von Anwendungen durch Programmverschleierung untersuchte, um die innere Funktionsweise einer Anwendung zu verbergen.


Während die meisten Schwachstellen in dieser Liste ziemlich spezifisch für APIs sind, ist das Problem der deaktivierten Sicherheitsfunktionen/aktivierten Debug-Funktionen/unzulässigen Berechtigungen eines, das überall auftreten kann. Es ist wahrscheinlich etwas häufiger in APIs anzutreffen, aber Angreifer werden oft versuchen, ungepatchte Schwachstellen und ungeschützte Dateien oder Verzeichnisse irgendwo in einem Netzwerk zu finden. Wenn sie auf eine API stoßen, bei der das Debugging aktiviert oder die Sicherheitsfunktionen deaktiviert sind, macht das ihre schändliche Arbeit nur ein wenig einfacher. Schlimmer noch, es gibt automatisierte Tools, um Sicherheitsfehlkonfigurationen zu erkennen und auszunutzen. Wenn Sie diese also in Ihrer Umgebung haben, besteht eine gute Chance, dass sie ausgenutzt werden, weshalb diese Schwachstelle es auf die OWASP-Liste der gefährlichen API-Schwachstellen geschafft hat.
Bevor wir mit dem Spaß beginnen, sehen Sie, ob Sie diese Debug-Herausforderung lösen können:
Wie schleicht sich der Fehler deaktivierte Sicherheitsfunktionen/aktivierte Debug-Funktionen/unzulässige Berechtigungen in eine API ein?
Um zu sehen, wie dieser mehrdimensionale API-Fehler in die Netzwerke gelangt, müssen wir ihn in seine Bestandteile zerlegen. Beginnen wir mit dem Problem der aktivierten Debugging-Funktionen. Debugging ist ein nützliches Werkzeug, das Entwicklern hilft, herauszufinden, warum Anwendungen nicht richtig funktionieren oder Fehler machen. Wenn Debugging aktiviert ist, werden bei Fehlern und Ausnahmen detaillierte Fehlerseiten generiert, so dass Entwickler sehen können, was schief gelaufen ist und Probleme beheben können. Es ist völlig in Ordnung, diese Funktion zu aktivieren, während sich eine Anwendung noch in der Entwicklung befindet.
Es gibt jedoch einen Grund, warum die meisten Frameworks mit Warnungen über die Ausführung des Debug-Modus in einer Produktionsumgebung kommen, wahrscheinlich direkt im Code, wo das Debugging aktiviert ist. Zum Beispiel:
# SICHERHEITSWARNUNG: nicht mit eingeschaltetem Debug in der Produktion ausführen!
DEBUG = True
In diesem Beispiel wurde das Debugging aktiviert. Die Django-Anwendung generiert detaillierte Fehlerseiten, wenn eine Ausnahme ausgelöst wird. Wenn dies in einer Produktionsumgebung geschieht, hätte ein Angreifer Zugriff auf diese Fehlerseiten, die Metadateninformationen über die Umgebung enthalten. Obwohl bei den meisten Frameworks das Debugging standardmäßig ausgeschaltet ist, vergisst man leicht, es wieder auszuschalten, wenn es während eines langen Entwicklungsprozesses aktiviert wurde. Wenn die Anwendung dann in eine Produktionsumgebung übergeht, bietet sie Angreifern viele Informationen darüber, wie sie eine Anwendung oder sogar einen ganzen Server oder ein Netzwerk kompromittieren können.
Während das Aktivieren des Debug-Modus meist ein eigenständiges Problem darstellt, wirken die Schwachstellen mit falschen Berechtigungen und deaktivierten Sicherheitsfunktionen oft zusammen. In einem realen Szenario, das von OWASP zur Verfügung gestellt wurde, verwendete ein Angreifer beispielsweise eine Suchmaschine, um eine Datenbank zu finden, die versehentlich mit dem Internet verbunden war. Da das beliebte Datenbankmanagementsystem seine Standardkonfiguration verwendete, war die Authentifizierung deaktiviert. Durch die Kombination der falschen Berechtigungen und der deaktivierten Sicherheitsfunktionen erlangte der Angreifer somit Zugriff auf Millionen von Datensätzen mit PII, persönlichen Einstellungen und Authentifizierungsdaten.
Beseitigung der deaktivierten Sicherheitsfunktionen/aktivierten Debug-Funktionen/unzulässigen Berechtigungsschwachstellen
Wahrscheinlich müssen Sie bei der Beseitigung dieser Schwachstelle einen zweigleisigen Ansatz wählen. Um den aktivierten Debug-Teil des Problems zu beseitigen, fügen Sie einfach eine Prüfung in den Entwicklungsprozess ein, um sicherzustellen, dass das Debugging deaktiviert wird, bevor eine API oder Anwendung in die Produktionsumgebung verschoben wird. In unserem Beispiel würde der richtige Befehl dazu folgendermaßen lauten:
# SICHERHEITSWARNUNG: nicht mit eingeschaltetem Debug in der Produktion ausführen!
DEBUG = False
Jetzt werden die Debug-Funktionen in der Django-Anwendung deaktiviert, indem das DEBUG-Flag auf False konfiguriert wird. Als Reaktion auf Fehler werden keine Fehlerseiten generiert. Wenn ein Angreifer dennoch Zugriff auf Fehlerseiten erhält, enthalten diese keine nützlichen Metadaten und stellen kein Risiko für die Anwendung dar.
Die Beseitigung von deaktivierten Sicherheitsfunktionen und Schwachstellen durch falsche Berechtigungen ist etwas schwieriger, da sie eine Vielzahl von spezifischen Schwachstellen umfassen können. Der beste Weg, sie zu stoppen, ist die Entwicklung eines standardisierten und wiederholbaren Prozesses, der eine schnelle und einfache Bereitstellung von gesperrten Assets in der Produktionsumgebung ermöglicht.
Selbst dann sollten Sie einen Prozess erstellen, bei dem Orchestrierungsdateien, API-Komponenten und Cloud-Dienste wie Amazon S3-Bucket-Berechtigungen ständig überprüft und aktualisiert werden. Bei dieser Überprüfung sollte auch die Gesamtwirksamkeit der Sicherheitseinstellungen in der gesamten Umgebung im Laufe der Zeit bewertet werden, um sicherzustellen, dass das Unternehmen seine API-Sicherheit stets verbessert.
Schauen Sie sich die Secure Code Warrior Blog-Seiten, um mehr über diese Schwachstelle zu erfahren und zu erfahren, wie Sie Ihr Unternehmen und Ihre Kunden vor den Auswirkungen anderer Sicherheitslücken schützen können. Sie können auch eine Demo der Schulungsplattform Secure Code Warrior ausprobieren, um alle Ihre Cybersecurity-Kenntnisse zu schärfen und auf dem neuesten Stand zu halten.

Während die meisten Schwachstellen in dieser Liste ziemlich spezifisch für APIs sind, ist das Problem der deaktivierten Sicherheitsfunktionen/aktivierten Debug-Funktionen/unzulässigen Berechtigungen eines, das überall auftreten kann. Es ist wahrscheinlich etwas häufiger in APIs anzutreffen, aber Angreifer werden oft versuchen, ungepatchte Schwachstellen und ungeschützte Dateien oder Verzeichnisse irgendwo in einem Netzwerk zu finden. Wenn sie auf eine API stoßen, bei der das Debugging aktiviert oder die Sicherheitsfunktionen deaktiviert sind, macht das ihre schändliche Arbeit nur ein wenig einfacher. Schlimmer noch, es gibt automatisierte Tools, um Sicherheitsfehlkonfigurationen zu erkennen und auszunutzen. Wenn Sie diese also in Ihrer Umgebung haben, besteht eine gute Chance, dass sie ausgenutzt werden, weshalb diese Schwachstelle es auf die OWASP-Liste der gefährlichen API-Schwachstellen geschafft hat.
Bevor wir mit dem Spaß beginnen, sehen Sie, ob Sie diese Debug-Herausforderung lösen können:
Wie schleicht sich der Fehler deaktivierte Sicherheitsfunktionen/aktivierte Debug-Funktionen/unzulässige Berechtigungen in eine API ein?
Um zu sehen, wie dieser mehrdimensionale API-Fehler in die Netzwerke gelangt, müssen wir ihn in seine Bestandteile zerlegen. Beginnen wir mit dem Problem der aktivierten Debugging-Funktionen. Debugging ist ein nützliches Werkzeug, das Entwicklern hilft, herauszufinden, warum Anwendungen nicht richtig funktionieren oder Fehler machen. Wenn Debugging aktiviert ist, werden bei Fehlern und Ausnahmen detaillierte Fehlerseiten generiert, so dass Entwickler sehen können, was schief gelaufen ist und Probleme beheben können. Es ist völlig in Ordnung, diese Funktion zu aktivieren, während sich eine Anwendung noch in der Entwicklung befindet.
Es gibt jedoch einen Grund, warum die meisten Frameworks mit Warnungen über die Ausführung des Debug-Modus in einer Produktionsumgebung kommen, wahrscheinlich direkt im Code, wo das Debugging aktiviert ist. Zum Beispiel:
# SICHERHEITSWARNUNG: nicht mit eingeschaltetem Debug in der Produktion ausführen!
DEBUG = True
In diesem Beispiel wurde das Debugging aktiviert. Die Django-Anwendung generiert detaillierte Fehlerseiten, wenn eine Ausnahme ausgelöst wird. Wenn dies in einer Produktionsumgebung geschieht, hätte ein Angreifer Zugriff auf diese Fehlerseiten, die Metadateninformationen über die Umgebung enthalten. Obwohl bei den meisten Frameworks das Debugging standardmäßig ausgeschaltet ist, vergisst man leicht, es wieder auszuschalten, wenn es während eines langen Entwicklungsprozesses aktiviert wurde. Wenn die Anwendung dann in eine Produktionsumgebung übergeht, bietet sie Angreifern viele Informationen darüber, wie sie eine Anwendung oder sogar einen ganzen Server oder ein Netzwerk kompromittieren können.
Während das Aktivieren des Debug-Modus meist ein eigenständiges Problem darstellt, wirken die Schwachstellen mit falschen Berechtigungen und deaktivierten Sicherheitsfunktionen oft zusammen. In einem realen Szenario, das von OWASP zur Verfügung gestellt wurde, verwendete ein Angreifer beispielsweise eine Suchmaschine, um eine Datenbank zu finden, die versehentlich mit dem Internet verbunden war. Da das beliebte Datenbankmanagementsystem seine Standardkonfiguration verwendete, war die Authentifizierung deaktiviert. Durch die Kombination der falschen Berechtigungen und der deaktivierten Sicherheitsfunktionen erlangte der Angreifer somit Zugriff auf Millionen von Datensätzen mit PII, persönlichen Einstellungen und Authentifizierungsdaten.
Beseitigung der deaktivierten Sicherheitsfunktionen/aktivierten Debug-Funktionen/unzulässigen Berechtigungsschwachstellen
Wahrscheinlich müssen Sie bei der Beseitigung dieser Schwachstelle einen zweigleisigen Ansatz wählen. Um den aktivierten Debug-Teil des Problems zu beseitigen, fügen Sie einfach eine Prüfung in den Entwicklungsprozess ein, um sicherzustellen, dass das Debugging deaktiviert wird, bevor eine API oder Anwendung in die Produktionsumgebung verschoben wird. In unserem Beispiel würde der richtige Befehl dazu folgendermaßen lauten:
# SICHERHEITSWARNUNG: nicht mit eingeschaltetem Debug in der Produktion ausführen!
DEBUG = False
Jetzt werden die Debug-Funktionen in der Django-Anwendung deaktiviert, indem das DEBUG-Flag auf False konfiguriert wird. Als Reaktion auf Fehler werden keine Fehlerseiten generiert. Wenn ein Angreifer dennoch Zugriff auf Fehlerseiten erhält, enthalten diese keine nützlichen Metadaten und stellen kein Risiko für die Anwendung dar.
Die Beseitigung von deaktivierten Sicherheitsfunktionen und Schwachstellen durch falsche Berechtigungen ist etwas schwieriger, da sie eine Vielzahl von spezifischen Schwachstellen umfassen können. Der beste Weg, sie zu stoppen, ist die Entwicklung eines standardisierten und wiederholbaren Prozesses, der eine schnelle und einfache Bereitstellung von gesperrten Assets in der Produktionsumgebung ermöglicht.
Selbst dann sollten Sie einen Prozess erstellen, bei dem Orchestrierungsdateien, API-Komponenten und Cloud-Dienste wie Amazon S3-Bucket-Berechtigungen ständig überprüft und aktualisiert werden. Bei dieser Überprüfung sollte auch die Gesamtwirksamkeit der Sicherheitseinstellungen in der gesamten Umgebung im Laufe der Zeit bewertet werden, um sicherzustellen, dass das Unternehmen seine API-Sicherheit stets verbessert.
Schauen Sie sich die Secure Code Warrior Blog-Seiten, um mehr über diese Schwachstelle zu erfahren und zu erfahren, wie Sie Ihr Unternehmen und Ihre Kunden vor den Auswirkungen anderer Sicherheitslücken schützen können. Sie können auch eine Demo der Schulungsplattform Secure Code Warrior ausprobieren, um alle Ihre Cybersecurity-Kenntnisse zu schärfen und auf dem neuesten Stand zu halten.

Klicken Sie auf den folgenden Link und laden Sie die PDF-Datei dieser Ressource herunter.
Secure Code Warrior ist für Unternehmen da, um den Code während des gesamten Softwareentwicklungszyklus zu schützen und eine Kultur zu schaffen, in der Cybersicherheit oberste Priorität hat. Unabhängig davon, ob Sie AppSec-Manager, Entwickler, CISO oder in einem anderen Bereich der Sicherheit tätig sind, können wir Ihnen dabei helfen, die Risiken zu reduzieren, die mit unsicherem Code verbunden sind.
Bericht anzeigenDemo-Termin vereinbarenMatias Madou, Ph.D., ist Sicherheitsexperte, Forscher, CTO und Mitbegründer von Secure Code Warrior. Matias promovierte an der Universität Gent im Bereich Anwendungssicherheit und konzentrierte sich dabei auf statische Analyselösungen. Später wechselte er zu Fortify in den USA, wo er erkannte, dass es nicht ausreicht, nur Codeprobleme zu erkennen, ohne den Entwicklern beim Schreiben von sicherem Code zu helfen. Dies inspirierte ihn dazu, Produkte zu entwickeln, die Entwickler unterstützen, den Aufwand für die Sicherheit verringern und die Erwartungen der Kunden übertreffen. Wenn er nicht an seinem Schreibtisch im Team Awesome sitzt, steht er gerne auf der Bühne und hält Vorträge auf Konferenzen wie der RSA Conference, BlackHat und DefCon.
Matias ist ein Forscher und Entwickler mit mehr als 15 Jahren praktischer Erfahrung im Bereich der Softwaresicherheit. Er hat Lösungen für Unternehmen wie Fortify Software und sein eigenes Unternehmen Sensei Security entwickelt. Im Laufe seiner Karriere hat Matias mehrere Forschungsprojekte zur Anwendungssicherheit geleitet, die zu kommerziellen Produkten geführt haben, und kann auf über 10 Patente verweisen. Wenn er nicht am Schreibtisch sitzt, ist Matias als Ausbilder für fortgeschrittene Anwendungssicherheitstrainings courses tätig und hält regelmäßig Vorträge auf globalen Konferenzen wie RSA Conference, Black Hat, DefCon, BSIMM, OWASP AppSec und BruCon.
Matias hat einen Doktortitel in Computertechnik von der Universität Gent, wo er die Sicherheit von Anwendungen durch Programmverschleierung untersuchte, um die innere Funktionsweise einer Anwendung zu verbergen.
Während die meisten Schwachstellen in dieser Liste ziemlich spezifisch für APIs sind, ist das Problem der deaktivierten Sicherheitsfunktionen/aktivierten Debug-Funktionen/unzulässigen Berechtigungen eines, das überall auftreten kann. Es ist wahrscheinlich etwas häufiger in APIs anzutreffen, aber Angreifer werden oft versuchen, ungepatchte Schwachstellen und ungeschützte Dateien oder Verzeichnisse irgendwo in einem Netzwerk zu finden. Wenn sie auf eine API stoßen, bei der das Debugging aktiviert oder die Sicherheitsfunktionen deaktiviert sind, macht das ihre schändliche Arbeit nur ein wenig einfacher. Schlimmer noch, es gibt automatisierte Tools, um Sicherheitsfehlkonfigurationen zu erkennen und auszunutzen. Wenn Sie diese also in Ihrer Umgebung haben, besteht eine gute Chance, dass sie ausgenutzt werden, weshalb diese Schwachstelle es auf die OWASP-Liste der gefährlichen API-Schwachstellen geschafft hat.
Bevor wir mit dem Spaß beginnen, sehen Sie, ob Sie diese Debug-Herausforderung lösen können:
Wie schleicht sich der Fehler deaktivierte Sicherheitsfunktionen/aktivierte Debug-Funktionen/unzulässige Berechtigungen in eine API ein?
Um zu sehen, wie dieser mehrdimensionale API-Fehler in die Netzwerke gelangt, müssen wir ihn in seine Bestandteile zerlegen. Beginnen wir mit dem Problem der aktivierten Debugging-Funktionen. Debugging ist ein nützliches Werkzeug, das Entwicklern hilft, herauszufinden, warum Anwendungen nicht richtig funktionieren oder Fehler machen. Wenn Debugging aktiviert ist, werden bei Fehlern und Ausnahmen detaillierte Fehlerseiten generiert, so dass Entwickler sehen können, was schief gelaufen ist und Probleme beheben können. Es ist völlig in Ordnung, diese Funktion zu aktivieren, während sich eine Anwendung noch in der Entwicklung befindet.
Es gibt jedoch einen Grund, warum die meisten Frameworks mit Warnungen über die Ausführung des Debug-Modus in einer Produktionsumgebung kommen, wahrscheinlich direkt im Code, wo das Debugging aktiviert ist. Zum Beispiel:
# SICHERHEITSWARNUNG: nicht mit eingeschaltetem Debug in der Produktion ausführen!
DEBUG = True
In diesem Beispiel wurde das Debugging aktiviert. Die Django-Anwendung generiert detaillierte Fehlerseiten, wenn eine Ausnahme ausgelöst wird. Wenn dies in einer Produktionsumgebung geschieht, hätte ein Angreifer Zugriff auf diese Fehlerseiten, die Metadateninformationen über die Umgebung enthalten. Obwohl bei den meisten Frameworks das Debugging standardmäßig ausgeschaltet ist, vergisst man leicht, es wieder auszuschalten, wenn es während eines langen Entwicklungsprozesses aktiviert wurde. Wenn die Anwendung dann in eine Produktionsumgebung übergeht, bietet sie Angreifern viele Informationen darüber, wie sie eine Anwendung oder sogar einen ganzen Server oder ein Netzwerk kompromittieren können.
Während das Aktivieren des Debug-Modus meist ein eigenständiges Problem darstellt, wirken die Schwachstellen mit falschen Berechtigungen und deaktivierten Sicherheitsfunktionen oft zusammen. In einem realen Szenario, das von OWASP zur Verfügung gestellt wurde, verwendete ein Angreifer beispielsweise eine Suchmaschine, um eine Datenbank zu finden, die versehentlich mit dem Internet verbunden war. Da das beliebte Datenbankmanagementsystem seine Standardkonfiguration verwendete, war die Authentifizierung deaktiviert. Durch die Kombination der falschen Berechtigungen und der deaktivierten Sicherheitsfunktionen erlangte der Angreifer somit Zugriff auf Millionen von Datensätzen mit PII, persönlichen Einstellungen und Authentifizierungsdaten.
Beseitigung der deaktivierten Sicherheitsfunktionen/aktivierten Debug-Funktionen/unzulässigen Berechtigungsschwachstellen
Wahrscheinlich müssen Sie bei der Beseitigung dieser Schwachstelle einen zweigleisigen Ansatz wählen. Um den aktivierten Debug-Teil des Problems zu beseitigen, fügen Sie einfach eine Prüfung in den Entwicklungsprozess ein, um sicherzustellen, dass das Debugging deaktiviert wird, bevor eine API oder Anwendung in die Produktionsumgebung verschoben wird. In unserem Beispiel würde der richtige Befehl dazu folgendermaßen lauten:
# SICHERHEITSWARNUNG: nicht mit eingeschaltetem Debug in der Produktion ausführen!
DEBUG = False
Jetzt werden die Debug-Funktionen in der Django-Anwendung deaktiviert, indem das DEBUG-Flag auf False konfiguriert wird. Als Reaktion auf Fehler werden keine Fehlerseiten generiert. Wenn ein Angreifer dennoch Zugriff auf Fehlerseiten erhält, enthalten diese keine nützlichen Metadaten und stellen kein Risiko für die Anwendung dar.
Die Beseitigung von deaktivierten Sicherheitsfunktionen und Schwachstellen durch falsche Berechtigungen ist etwas schwieriger, da sie eine Vielzahl von spezifischen Schwachstellen umfassen können. Der beste Weg, sie zu stoppen, ist die Entwicklung eines standardisierten und wiederholbaren Prozesses, der eine schnelle und einfache Bereitstellung von gesperrten Assets in der Produktionsumgebung ermöglicht.
Selbst dann sollten Sie einen Prozess erstellen, bei dem Orchestrierungsdateien, API-Komponenten und Cloud-Dienste wie Amazon S3-Bucket-Berechtigungen ständig überprüft und aktualisiert werden. Bei dieser Überprüfung sollte auch die Gesamtwirksamkeit der Sicherheitseinstellungen in der gesamten Umgebung im Laufe der Zeit bewertet werden, um sicherzustellen, dass das Unternehmen seine API-Sicherheit stets verbessert.
Schauen Sie sich die Secure Code Warrior Blog-Seiten, um mehr über diese Schwachstelle zu erfahren und zu erfahren, wie Sie Ihr Unternehmen und Ihre Kunden vor den Auswirkungen anderer Sicherheitslücken schützen können. Sie können auch eine Demo der Schulungsplattform Secure Code Warrior ausprobieren, um alle Ihre Cybersecurity-Kenntnisse zu schärfen und auf dem neuesten Stand zu halten.
Inhaltsverzeichnis
Matias Madou, Ph.D., ist Sicherheitsexperte, Forscher, CTO und Mitbegründer von Secure Code Warrior. Matias promovierte an der Universität Gent im Bereich Anwendungssicherheit und konzentrierte sich dabei auf statische Analyselösungen. Später wechselte er zu Fortify in den USA, wo er erkannte, dass es nicht ausreicht, nur Codeprobleme zu erkennen, ohne den Entwicklern beim Schreiben von sicherem Code zu helfen. Dies inspirierte ihn dazu, Produkte zu entwickeln, die Entwickler unterstützen, den Aufwand für die Sicherheit verringern und die Erwartungen der Kunden übertreffen. Wenn er nicht an seinem Schreibtisch im Team Awesome sitzt, steht er gerne auf der Bühne und hält Vorträge auf Konferenzen wie der RSA Conference, BlackHat und DefCon.

Secure Code Warrior ist für Unternehmen da, um den Code während des gesamten Softwareentwicklungszyklus zu schützen und eine Kultur zu schaffen, in der Cybersicherheit oberste Priorität hat. Unabhängig davon, ob Sie AppSec-Manager, Entwickler, CISO oder in einem anderen Bereich der Sicherheit tätig sind, können wir Ihnen dabei helfen, die Risiken zu reduzieren, die mit unsicherem Code verbunden sind.
Demo-Termin vereinbarenDownloadHilfreiche Ressourcen für den Einstieg
Themen und Inhalte der Sicherheitsschulung
Die branchenweit besten Inhalte werden unter Berücksichtigung der Kundenrollen ständig weiterentwickelt und an die sich ständig verändernde Softwareentwicklungsumgebung angepasst. Es werden Themen angeboten, die alle Bereiche von KI bis hin zu XQuery-Injection abdecken und für verschiedene Rollen geeignet sind, von Architekten und Ingenieuren bis hin zu Produktmanagern und QA-Mitarbeitern. Sehen Sie sich vorab an, was der Inhaltskatalog nach Themen und Rollen zu bieten hat.
Die Kamer van Koophandel setzt Maßstäbe für entwicklergesteuerte Sicherheit in großem Maßstab
Die Kamer van Koophandel berichtet, wie sie sicheres Codieren durch rollenbasierte Zertifizierungen, Trust Score-Benchmarking und eine Kultur der gemeinsamen Verantwortung für Sicherheit in die tägliche Entwicklungsarbeit integriert hat.
Bedrohungsmodellierung mit KI: So wird jeder Entwickler zum Bedrohungsmodellierer
Sie werden besser gerüstet sein, um Entwicklern dabei zu helfen, Ideen und Techniken zur Bedrohungsmodellierung mit den KI-Tools zu kombinieren, die sie bereits verwenden, um die Sicherheit zu erhöhen, die Zusammenarbeit zu verbessern und von Anfang an widerstandsfähigere Software zu entwickeln.
Hilfreiche Ressourcen für den Einstieg
Cybermon ist zurück: Die KI-Mission zum Besiegen des Bosses ist jetzt auf Abruf verfügbar.
Cybermon 2025 Bit The Boss ist jetzt das ganze Jahr über bei SCW verfügbar. Stärken Sie die Entwicklung von Sicherheits-KI in großem Maßstab durch den Einsatz fortschrittlicher KI/LLM-Sicherheitslösungen.
Erläuterung des Gesetzes zur Cyber-Resilienz: Bedeutung der Entwicklung von Sicherheitsdesign-Software
Erfahren Sie mehr über die Anforderungen und Anwendungsbereiche des EU-Cyberresilienzgesetzes (CRA) und darüber, wie sich Ingenieurteams durch Design, Praktiken, Schwachstellenvermeidung und die Einrichtung einer Entwicklerumgebung sicher vorbereiten können.
Erfolgsfaktor 1: Definierte und messbare Erfolgskriterien
Enabler 1 bietet eine zehnteilige Reihe von Erfolgsfaktoren, die zeigen, wie sichere Codierung zu Geschäftsergebnissen wie einer schnelleren Risikominderung und Kostensenkung für die Reifung langfristiger Programme beitragen kann.




%20(1).avif)
.avif)
