Download the PHP package marein/symfony-standard-headers-csrf-bundle without Composer
On this page you can find all versions of the php package marein/symfony-standard-headers-csrf-bundle. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download marein/symfony-standard-headers-csrf-bundle
More information about marein/symfony-standard-headers-csrf-bundle
Files in marein/symfony-standard-headers-csrf-bundle
Package symfony-standard-headers-csrf-bundle
Short Description Protect symfony applications against CSRF attacks with the help of standard headers.
License MIT
Informations about the package symfony-standard-headers-csrf-bundle
symfony-standard-headers-csrf-bundle
Table of contents
- Overview
- How it works?
- Installation and requirements
- Configuration
- Public api
Overview
Protect symfony applications against CSRF attacks with the help of standard headers.
The mechanism to prevent CSRF attacks which is used by this bundle can best be read under OWASP. The technique is named "Verifying Origin With Standard Headers".
How it works?
This bundle is based on the headers Host
, Origin
and Referer
. They're part of the
forbidden headers
and cannot be changed programmatically with a standard browser. Please read the
OWASP
page carefully as this technique may not work in all cases.
This bundle returns a status code 403
if the request isn't safe.
A request is safe if at least one of the following criteria is met:
- the http method is a safe http method.
- the request path matches one of the
allowed_paths
from the configuration. - the origin header matches the
Host
header or one of theallowed_origins
from the configuration. fallback_to_referer
is enabled and theReferer
header matches theHost
header or one of theallowed_origins
from the configuration.allow_null_origin
is enabled and theOrigin
header is equal to"null"
.
If there're trusted proxies configured in your symfony application,
X-Forwarded-Host
is used instead of Host
.
Installation and requirements
Add the bundle to your project.
Add the bundle in the kernel. This can be different for your setup.
Configuration
This is an example of all configurations in yaml format.
Public api
Only the bundle configuration is part of the public api. Everything else can change and is not considered a breaking change. Please don't use classes or services directly.
All versions of symfony-standard-headers-csrf-bundle with dependencies
symfony/http-foundation Version ^5.1 || ^6.0 || ^7.0
symfony/config Version ^5.1 || ^6.0 || ^7.0
symfony/dependency-injection Version ^5.1 || ^6.0 || ^7.0
symfony/http-kernel Version ^5.1 || ^6.0 || ^7.0