Skip to main content

An SSL-enabled development server for Django. Supports latest versions of Django and Python

Project description

https://img.shields.io/pypi/v/django-sslserver-v2.svg https://img.shields.io/pypi/pyversions/django-sslserver-v2.svg

Django SSL Server v2 is a SSL-enabled development server for the Django Framework, a clone of django-sslserver. This project is actively maintained and supports the latest version of Django and Python.

Please note that this should not be used for production setups. This app is intended for special use-cases. Most people should instead do a proper production deployment where a real webserver such as Apache or NGINX handles SSL.

Getting Started

Install the module in your Python distribution or virtualenv:

$ pip install django-sslserver-v2

Add the application to your INSTALLED_APPS:

INSTALLED_APPS = (...
"sslserver",
...
)

Start a SSL-enabled debug server:

$ python manage.py runsslserver

and access app on https://localhost:8000 or start server on specified port:

$ python manage.py runsslserver 127.0.0.1:9000

IPv6 support:

$ python manage.py runsslserver -6 [::]:7443

You’ll now be able to access your Django app on https://localhost:9000/

Browser Certificate Errors

Using the default settings, your local browser will make all sorts of noise that it doesn’t trust the certificate. This is expected.

Django SSL Server ships “batteries included” with a self-signed server certificate. With self-signed certificates, the server is effectively telling the user, “I’m such-and-such server, because I said so”. Whereas, with a commercial SSL certificate, the server tells the user, “I’m Bank of America, because VeriSign said so (or any other commercial certificate authority).”

There are two options for making the certificate warning go away in development:

Option 1: Tell your browser to explicitly trust the certificate. You can do this in your browser’s “advanced settings” tab, by installing sslserver/certs/development.crt as a trusted certificate. The mechanism for this varies from browser to browser.

Option 2: Use a certificate from a CA that your browser trusts, for example Letsencrypt. If you have a certificate/key pair from a certificate authority, you can tell Django SSL Server to use it with the following arguments:

$ python manage.py runsslserver --certificate /path/to/certificate.crt --key /path/to/key.key

Third-Party Static File Handlers

If you’re using a wrapper around your WSGI application such as dj_static or WhiteNoise, you probably want to let it handle serving static files. Otherwise, you may see 404s when requesting static files. You can disable the default behavior by using the --nostatic option.

Getting Involved

Feel free to open pull requests or issues. GitHub is the canonical location of this project.

Special Thanks

Special thanks to @teddziuba for building django-sslserver and all the contributers

Project details


Release history Release notifications | RSS feed

This version

1.0

Download files

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

Source Distribution

django-sslserver-v2-1.0.tar.gz (11.2 kB view details)

Uploaded Source

Built Distribution

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

django_sslserver_v2-1.0-py3-none-any.whl (11.9 kB view details)

Uploaded Python 3

File details

Details for the file django-sslserver-v2-1.0.tar.gz.

File metadata

  • Download URL: django-sslserver-v2-1.0.tar.gz
  • Upload date:
  • Size: 11.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for django-sslserver-v2-1.0.tar.gz
Algorithm Hash digest
SHA256 4e1f84bc35a989bae25937ac017a6616ef04fdf99923cbba7b5c5dca27090f7c
MD5 98c317c3cfe6c1fd08f7c614ccd6b5fa
BLAKE2b-256 735a8161cba4e470f71d1bb4e793b9ccdb9570ea1c4f5da1c0860cb1b67333dc

See more details on using hashes here.

File details

Details for the file django_sslserver_v2-1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for django_sslserver_v2-1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9f2f191534e74fc1a1a40724fe4e5293815acb92016770f1393524e67bdcf340
MD5 14429d811885120f9259ae89fbca0459
BLAKE2b-256 86a0bfc571b1905097af3c1c21d6a78f54fde50bfcb0495c21358bff7030cd21

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