This is a collection of Djanog projects that I have built while learning Django and other useful web technologies, primarily, HTML, Django, CSS, JavaScript, jQuery, etc.
Following are the short description of each of these Django projects. For more details, please read the README.md file available under each of these projects.
This is a simple Django project.
This project has a single HTML page showing "Hello World".
It is a single page application:
- Taking input on page "home.html"
- Printing output on the same page "home.html"
This project is making use of the following technologies:
- Django
- JavaScript / AJAX / jQuery
- CSS
This is a sample Celery/Django project.
In this project, we will learn to offload the time-consuming tasks to an asynchronous process which will not hinder the responsiveness of the web application so that user don't feel like stuck.
Following technologies have been used in this project:
- Django
- CSS
- JavaScript / AJAX / jQuery
- Celery [KEY ROLE]
This is a sample Celery/Django project.
In this project, we will learn to offload the time-consuming tasks to an asynchronous process which will not hinder the responsiveness of the web application so that user don't feel like stuck. Along with this, we will keep checking the status of the offloaded task in this project.
Following technologies are the key focus in this project:
- Django
- Celery
- RPC
This is a simple Djanog project to demonstrate the working of WebSockets in Django.
In this project, following is accomplished:
- On clicking a HTML button, the javascript function will connect with the backend (a Django function) through a web-socket
- This Django function will generate random numbers and send them at an interval of 1 second to the javascript function
- The same javascript function will display that randomly generated number on the HTML page
This project is updating a progress bar to show the progress of a background running task.
The background running task is simulating a high computational task. This task is made to run in background by using Celery.
Following is the execution flow of this project:
- Click on the "START" button
- This will connect the front-end (i.e., javascript) with a web-socket (Django at backend)
- This web-socket code (Django at backend) will accept the connection request and initiate a Celery task (in Python), i.e., in background
- This web-socket (Django at backend) will get the progress made by the Celery task (Python code) and send it to the connected front-end (javascript)
- The front-end (javascript) will update the progress-bar and its value (i.e., HTML page)
This project is updating an indeterminate progress bar to show the progress of a background running task whose progress cannot be determined.
The background running task is simulating a high computational task. This task is made to run in background by using Celery.
Following is the execution flow of this project:
- Click on the "START" button
- This will connect the front-end (i.e., javascript) with a web-socket (Django at backend)
- This web-socket code (Django at backend) will accept the connection request and initiate a Celery task (in Python), i.e., in background
- This web-socket (Django at backend) will send a signal to the front-end (i.e., javascript) that the background task has started. The front-end (i.e., javascript) script will update the same on the interface by showing status as "Started" and start the indeterminate progress bar
Following are the technologies used to develop this project:
- HTML / CSS
- JavaScript / jQuery
- Django
- Celery
- WebSocket
This project is just to demonstrate the use of VGG16 model at the backend of a Django app.
In this project, a VGG16 model is deployed that will process the passed images from the front-end and make predictions. Then, the Django back-end will share those predictions with the front-end which will show them to the user.
Following is the execution flow:
- Use will upload a number of images by clicking on a "Browse" button.
- Once those images are selected, the next page will show those images just for the user confirmation. The user will confirm the uploaded images by clicking on a "Submit" button at the bottom of this page.
- As the user clicks on the "Submit" button, the from-end will pass those images to the Django back-end.
- This Django back-end will process the passed images, i.e., resizing; and then pass them to the VGG16 model. This model will make predictions by processing these images.
- After the VGG16 model generate predictions, the Django backend will send those predictions to the front-end to present the result to the user.
Following are the technologies used in this project:
- Django
- HTML / CSS
- JavaScript / jQuery / AJAX
- Celery
- WebSocket
This project is demonstrating the upload of image files. The progress of upload is shown by a progress bar.
Following are the technologies used in this project:
- HTML / CSS
- JavaScript / jQuery / AJAX
- Django
This project is demonstrating signup and signin functionality. For the same Postgresql database is used.
This project is just to learn CI/CD (Continuous Integration/Continuous Delivery) by using GitHub Actions and AWS.
Following are the technologies used in this project:
- Django
- uWSGI
- Nginx
- GitHub Actions (for CI/CD pipeline)
- AWS EFS (Elastic File System)
- AWS EC2
This may further get extended by Docker and Kubernetes in future.
This project is demonstrating the use of the following technologies for a production level Django project in order to make it secure, scalable, and durable:
- Django: Django is a Pythong based web framework for the development of web applications. It is quite suitable to develop heavy web applications and it has been used by a number of big companies for their products.
- Docker (or Docker Compose): It helps to containerize our applications so that we don't have to struggle with installation and version compatibility issues while porting and deploying our applications from the development machine to the server. Apart from this, it also makes applications secure due to their sandboxing.
- Nginx: Nginx is reverse-proxy web server. It is quite popular among big companies as it is quite safe, scalable, and fast (perfect for production level applications).
- uWSGI: Since web servers don't understand Python, thus uWSGI (Web Server Gateway Interface) helps them to server Python applications.
This project is to demonstrate the working of Docker Compose. Here, two docker containers are created to run the following:
- app: "app" is a docker container (or service, in terms of Docker Compose). In this docker container, a Python script runs that hits postgresql database running in another docker container with name "db". This script builds connection with the database running in the another container, insert data and get the data stored in the database.
This Python script is a non-interactive script. - db: "db" is another docker container (or service, in terms of Docker container). In this container, a Postgresql database runs and listens on port 5432. For the purpose of connection, port 5432 is exposed.
In this project, following modules are running in separate docker container:
- Django app & uWSGI
- Nginx
- Postgresql database
All these modules are running in different docker containers (i.e., total 3 containers) and all these containers are managed by a Docker Compose file (i.e., a YML file).