Debian 12 bookworm
Sponsored Link

Django 4 : Install2023/07/14

 
Install Django which is Python Web Application Framework.
[1] Install Django under the Python venv. It's possible to do for any common user.
debian@dlp:~$
python3 -m venv --system-site-packages ~/django

debian@dlp:~$
source ~/django/bin/activate

(django) debian@dlp:~$
pip3 install 'Django>=4,<5'

Collecting Django<5,>=4
  Downloading Django-4.2.3-py3-none-any.whl (8.0 MB)
Collecting asgiref<4,>=3.6.0
  Downloading asgiref-3.7.2-py3-none-any.whl (24 kB)
Collecting sqlparse>=0.3.1
  Downloading sqlparse-0.4.4-py3-none-any.whl (41 kB)
Installing collected packages: sqlparse, asgiref, Django
Successfully installed Django-4.2.3 asgiref-3.7.2 sqlparse-0.4.4

(django) debian@dlp:~$
django-admin --version

4.2.3
# to exit from venv, run like follows

(django) debian@dlp:~$
deactivate

debian@dlp:~$
[2] Create a test project.
If Firewalld is running and also access to Django from other Hosts, Allow ports you plan to use with root privilege before it. (example below uses [8000/tcp])
debian@dlp:~$
source ~/django/bin/activate
# create testproject

(django) debian@dlp:~$
django-admin startproject testproject

(django) debian@dlp:~$
cd testproject

# configure database (default is SQLite)

(django) debian@dlp:~/testproject$
python manage.py migrate
# create admin user

(django) debian@dlp:~/testproject$
python manage.py createsuperuser

Username (leave blank to use 'debian'):
debian

Email address:
debian@dlp.srv.world

Password:
Password (again):
Superuser created successfully.
(django) debian@dlp:~/testproject$
vi testproject/settings.py
# line 28 : set if you allow to access to Django from other Hosts
# specify Hosts with comma separated
# if allow all, specify like follows

ALLOWED_HOSTS = [
'*'
]
# start server

(django) debian@dlp:~/testproject$
python manage.py runserver 0.0.0.0:8000

Watching for file changes with StatReloader
Performing system checks...

System check identified no issues (0 silenced).
July 14, 2023 - 00:00:30
Django version 4.2.3, using settings 'testproject.settings'
Starting development server at http://0.0.0.0:8000/
Quit the server with CONTROL-C.
[4] Access to the [(server's hostname or IP address):8000/] from a client computer. It's OK if following site is displayed normally.
[5] It's possible to use admin site on [(server's hostname or IP address):8000/admin].
[6] Create a test application to try to use Django.
debian@dlp:~$
source ~/django/bin/activate
(django) debian@dlp:~$
cd testproject

(django) debian@dlp:~/testproject$
python manage.py startapp test_app

(django) debian@dlp:~/testproject$
vi test_app/views.py
# add to the end

from django.http import HttpResponse
def main(request):
    html = '<html>\n' \
           '<body>\n' \
           '<div style="width: 100%; font-size: 40px; font-weight: bold; text-align: center;">\n' \
           'Django Test Page\n' \
           '</div>\n' \
           '</body>\n' \
           '</html>\n'
    return HttpResponse(html)

(django) debian@dlp:~/testproject$
vi testproject/urls.py
# line 18, 22 : add like follows

from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    path('admin/', admin.site.urls),
    path('test_app/', include('test_app.urls')),
]

(django) debian@dlp:~/testproject$
vi test_app/urls.py
# create new

from django.urls import path
from .views import main

urlpatterns = [
    path('', main, name='home')
]

(django) debian@dlp:~/testproject$
vi testproject/settings.py
# line 33 : add test application in [INSTALLED_APPS] section

INSTALLED_APPS = (
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'test_app',
)

(django) debian@dlp:~/testproject$
python manage.py runserver 0.0.0.0:8000

[7] Access to the [(server's hostname or IP address):8000/testapp/] from a client computer. It's OK if testapp is displayed normally.
Matched Content