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:~$
(django) debian@dlp:~/testproject$ cd 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. |
Sponsored Link |