Skip to main content

TODO

Project description

django_referer_csrf

This project has 2 goals:

  1. Simplifiy django's CSRF protection so that developers don't need to worry about the token
  2. Make it easier for view code to invoke CSRF protection dynamically

The token isn't needed

https://security.stackexchange.com/a/197269

On https sites, django's csrf protection requires that the request's referer header matches the request's host header. This check makes the entire CSRF token redundant. The token check provides no extra security on top of the referer check.

Django skips the referer check on non-https sites, which is somewhat advantageous (it means that users who configure their web browsers not submit a referer header can still submit forms).

Our validator actually looks for a valid origin header or referer header. Modern browsers follow the (newish) spec, which is to send an origin header with every request other than head/get. This means that if users have the referer header disabled, they can still pass our CSRF check.

Usage

  • pip install django_referer_csrf
  • in your MIDDLEWARE setting, replace django.middleware.csrf.CsrfViewMiddleware with django_referer_csrf.Middleware

With this middleware, you can still use Djangos's csrf_exempt decorators.

If you want to apply the CSRF protection based on dynamic conditions in view code, just check to see what the Middleware.process_view() does and replicate that.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django_referer_csrf-0.3.0.tar.gz (3.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_referer_csrf-0.3.0-py3-none-any.whl (4.8 kB view details)

Uploaded Python 3

File details

Details for the file django_referer_csrf-0.3.0.tar.gz.

File metadata

  • Download URL: django_referer_csrf-0.3.0.tar.gz
  • Upload date:
  • Size: 3.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.10

File hashes

Hashes for django_referer_csrf-0.3.0.tar.gz
Algorithm Hash digest
SHA256 143706ad7ead6418f11bead9a68890f98cc694abb972e9178f59defaa13b84c3
MD5 53295535953bec4cad876f1e9cbfa38c
BLAKE2b-256 5c4130b4f8fd898479fd5e3a66579d639377e1583f36bfb70e6cb6c7a3a91faa

See more details on using hashes here.

File details

Details for the file django_referer_csrf-0.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for django_referer_csrf-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6c2098c31ba1c57f9132d971fa8b50b4320c9d5de472414346eb6cee0434a4d9
MD5 68214b31c1299134eeff7cd10909e20f
BLAKE2b-256 c06a8c94372e2fadc8edb3fda3e15858b8e87b51ff8377a0b9e42c053a28b23b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page