Glossar App Entwicklung

Content Security Policy (CSP)

CSP ist eine Sicherheitsrichtlinie für Webanwendungen, die es ermöglicht, die Quellen von Inhalten wie Skripten, Bildern, Stylesheets und anderen Ressourcen zu kontrollieren, um die Ausführung von unsicheren oder bösartigen Inhalten zu verhindern. Diese Richtlinie hilft dabei, die Angriffsfläche von Webanwendungen zu reduzieren und schützt Benutzer vor verschiedenen Sicherheitsbedrohungen wie Cross-Site Scripting (XSS), Clickjacking und Dateninjektion.

CSP wird in der Regel durch das Setzen des Content-Security-Policy HTTP-Headers oder durch das Hinzufügen eines <meta> Tags im HTML-Code der Webseite implementiert. Eine CSP-Richtlinie besteht aus einer Reihe von Direktiven, die die erlaubten Quellen für verschiedene Ressourcentypen angeben. Einige häufig verwendete CSP-Direktiven sind:

  • default-src: Gibt die Standardquellen für alle Ressourcentypen an, wenn keine spezifische Direktive für einen bestimmten Ressourcentyp definiert ist.
  • script-src: Legt die erlaubten Quellen für Skripte fest.
  • img-src: Gibt die erlaubten Quellen für Bilder an.
  • style-src: Legt die erlaubten Quellen für Stylesheets fest.
  • font-src: Gibt die erlaubten Quellen für Schriftarten an.
  • frame-src: Legt die erlaubten Quellen für eingebettete Frames fest.
  • connect-src: Gibt die erlaubten Quellen für Verbindungen über XMLHttpRequest, Fetch API, WebSocket und EventSource an.

Bei der Implementierung einer CSP-Richtlinie ist es wichtig, die richtige Balance zwischen Sicherheit und Benutzerfreundlichkeit zu finden. Eine zu restriktive Richtlinie kann dazu führen, dass legitime Inhalte blockiert werden und die Funktionalität der Webanwendung beeinträchtigt wird, während eine zu lockere Richtlinie möglicherweise nicht ausreichend Schutz bietet.

Es ist empfehlenswert, die CSP-Richtlinie schrittweise zu entwickeln und zu testen, um sicherzustellen, dass sie den Anforderungen der Webanwendung entspricht und die Sicherheit der Benutzer gewährleistet. Zusätzlich sollten Webentwickler sicherstellen, dass alle von ihnen verwendeten externen Ressourcen vertrauenswürdig sind und die erforderlichen Sicherheitsvorkehrungen getroffen wurden.