0x0017 - Django Getting Started
data:image/s3,"s3://crabby-images/d63b1/d63b1625ccdabc948ba5bbe97eb2ff2781087221" alt="0x0017 - Django Getting Started"
Django is a web framework based upon the Python language. Large professional sites such as Instagram, Spotify, Youtube use Django.
Programmers prefer using Python because it means faster development - especially when you are using stepping debuggers such as Pycharm. Not only that but Pycharm Professional series come with Django support natively built-in.
sudo apt install python3 python3-pip
sudo pip3 install django
For this introductionary tutorial - we are working in Pycharm Professional 2022.2.4. We create a new project..
data:image/s3,"s3://crabby-images/9c02f/9c02f4f2e3f442249c5a7281f2ee544c46fc1268" alt=""
The entire skeletal framework is built for us:
If we were to do this from the command line we would use:
django-admin startproject <project>
data:image/s3,"s3://crabby-images/1a64a/1a64a92c72a5863d266036489010cb46163ca02c" alt=""
We are working from the base tutorial. What we might cover could be redundant from it - but it reinforces the understanding of it's structure. Going over the standard structure..
data:image/s3,"s3://crabby-images/c5652/c565215d16efa518e9fa53c96420eace56373c1e" alt=""
- mysite/ is a container for the project.
- manage.py Django project manager.
- mysite/mysite/ is the Python package
- mysite/__init__.py An empty file that tells Python that this directory should be considered a Python package.
- mysite/settings.py Settings for the project.
- mysite/urls.py URL mappings for the project
- mysite/asgi.py entry point fro ASGI-compatible web servers.
- mysite/wsgi.py entry point fro WSGI-compatible web servers.
To run the server:
python manage.py runserver
data:image/s3,"s3://crabby-images/974ea/974ea8caf8746681c9ea4bc8d797573524172b2e" alt=""
We can see it has stood up a listener at 127.0.0.1:8000 - what is there?
data:image/s3,"s3://crabby-images/527b3/527b3a1c2a9934f65f01d4b2368a923c9684323a" alt=""
A full web presentation front is there for us.
We can set how/what ports it listens on:
python3 manage.py runserver 0.0.0.0:8000
# to open any port below 1024 requires root
sudo python3 manage.py runserver 0.0.0.0:80
- Management of your Django application is done through the manage.py manager and this is built-in to Pycharm Pro:
Even autocomplete is built-in! - It shows us 'startapp' Doing this from the command line would simply be:
We can see it has added a folder and a structure inside it:
We edit views to add our first view:
data:image/s3,"s3://crabby-images/f7159/f7159ffbd1f613a5cdf0c8ac9b6db33657c7b20a" alt=""
Now we need to map the view to a URL, we add url.py in the same directory structure:
data:image/s3,"s3://crabby-images/7d411/7d411fb86a0345c70bd66533a9f654794d149411" alt=""
This app url now needs integration into the master URL file:
data:image/s3,"s3://crabby-images/d9114/d911411f68845014d2632811b4d4654b99f88a11" alt=""
data:image/s3,"s3://crabby-images/b41f8/b41f8a55d27ab331106830ac1cbfb0a1d1948bb1" alt=""
Interestingly django has it's own auto-debugging page updates - currently the guide is not working.
data:image/s3,"s3://crabby-images/33652/33652aad0ca42cd6853cea0e174afc335ae737ec" alt=""
We found our error - a simple / missing:
data:image/s3,"s3://crabby-images/db4ff/db4ff77a73f8f80bb6d3fc384a84b5b24dcae782" alt=""
Changed to:
data:image/s3,"s3://crabby-images/43f12/43f126c9592dcaa3df70fd1da9cce92920d1713d" alt=""
Next we go over the settings.py file and then we do a migrate.
python3 manage.py migrate
data:image/s3,"s3://crabby-images/e0a14/e0a14ed1085e1ba87d9a16fb8d05a8d2163c62f8" alt=""
Our application addition to the settings.py is a little different as the directory name of the project is different:
data:image/s3,"s3://crabby-images/b619c/b619c15edc519346e074c528e1002921474667e6" alt=""
data:image/s3,"s3://crabby-images/d0b19/d0b1962c577e71f875833f60fcf1cd493335f081" alt=""
- Note: 'django_learn_a' matched the project module 'django_learn_a'
By the guide we define our data model:
data:image/s3,"s3://crabby-images/85edc/85edc6024ab65d8fdae4200fb841e4682029b38f" alt=""
And then activate it with:
python3 manage.py makemigrations polls
data:image/s3,"s3://crabby-images/ffd89/ffd897e2d6917b685b3b581bab995638729cb03d" alt=""
Understanding that:
data:image/s3,"s3://crabby-images/80f77/80f7743933fd9fb240181cf832de747b2d20bd9a" alt=""
Now we will create the superuser:
data:image/s3,"s3://crabby-images/3a4e1/3a4e186b5cb0a74513876e5f357b7bfe6da2397d" alt=""
And we re-run the server to access the admin:
data:image/s3,"s3://crabby-images/0393e/0393e599250e7747801ad50789c90c69edcfa339" alt=""
data:image/s3,"s3://crabby-images/be689/be6893607b1a8da7a8051812678e1778e2ff1071" alt=""
The administration is built-in:
data:image/s3,"s3://crabby-images/a884e/a884e77d1e62f08f47e66360012c81afd1e786f2" alt=""
Finally we register our question class in the admin.py
data:image/s3,"s3://crabby-images/7d309/7d309aa5a8197cfe1db35299b1cf0a0a8d5cda1b" alt=""
The above actually did not work, we had to be explicit in the path importation:
data:image/s3,"s3://crabby-images/6eada/6eada654911fa8a58e29919fbee3f8e016f98e5d" alt=""
A complete manager for the data object is already done where we have added the Question() class:
data:image/s3,"s3://crabby-images/ea092/ea0929a96d6a60bd3aad767d29c252006dd1b33a" alt=""
With it our console is is logging the accesses:
data:image/s3,"s3://crabby-images/62398/6239888e3765258e3a62259b1ebc9256690aa97b" alt=""