Virtual Environment
pip install virtualenv
Django
pip install django
WhiteNoise
This package is for Deployment
pip install whitenoise
Before you get started, kindly read These get to start tutorial
Please, before you install these packages, kindly explore the entire documentation of this repository.
First thing is you need to install the
Virtual Environment
orVirtualenv
on your devicepip install virtualenv
. Then after you install the Virtual Environment, you need to add your virtual environment on your project, just type to your terminalvirtualenv venv
orpython -m venv venv
. The most common name of your environment isvenv
, if you want to havecollaborators
,venv
is the best name because it is universal. Next is activate the script by executing this to your terminal: (btw, don't include the hashtag it is just a comment)
# For Windows
.\venv\Scripts\activate
# For Linux
source venv/Lib/activate
Then you may now start installing Django. Also, once you've already created
venv
you don't need to create another one, just activate and start running the package withpython manage.py runserver
. Always take note that, you must install venv aligned with your DjangoProject, it will create conflicts to your program. And lastly, if you want to finish or deactivate the virtual environmant, just type:
deactivate
to your terminal.
It is to avoid the different errors you may have to your entire device, sprcially some data might be deleted. So the
Virtual Environment
is a way for you to protect your device, it creates a viretual storage or emulation of your device.
This file includes all the package you installed in your virtual environment or what we call
venv
. The code below is a terminal script you need to execute to automatically generate arequirements.txt
.
pip freeze > requirements.txt
Before you install these packages from requirements.txt, you've must activate the
virtual environment
first. To activate, just go to these section
pip install -r requirements.txt
Please note that if you start a project, you need first to activate the
Virtual Environment
. So first thing is you need to install django to your devicepip install django
and after you executed it, you may now create a new project. To create a project, kindly execute this to your terminal:
django-admin startproject ProjectName
Then you may see a new folder which is
ProjectName (if you use the same name from this tutorial)
. Inside of that folder, there's also another folder, same name as theProjectName
. It is the main of your website or program. You may also see themanage.py
inside of yourPeojectName
.
To start an app or component on django, you've must need to go to your project name, by simply using:
cd ProjectName
Once you've executerd this you may now start creating a new app or component. To create one, just use this sample format:
django-admin startapp ProjectApp
Take this as a note, you must not use the AppName, same as the ProjectName, it will having a conflict, since they were going to create some files and new directories.
So you see the views.py inside of your
ProjectApp
, just go there and create a new function in python like this:
from django.shortcuts import render
from django.http import HttpResponse
# Create your views here.
def a(request):
return HttpResponse("<h3>Hello World</h3>")
The defaule code inside of your views.py is:
from django.shortcuts import render
# Create your views here.
You may also use html files, but it is later on our documentation
To connect the app to your project, you need first to create a new file in your
PeojectApp
and name iturls.py
. It is generalized, you don't need to useurl.py
, it may cause error, so it must beurls.py
. Inside of `urls.py, add these code:
form django.http import path
urlpatterns = [
]
In this code, the urlpatterns must not be a different variable, it may also turns into an error. next is you need to unclude your function form your views.py by using this code:
from django.http import path
from . import views
urlpatterns = [
path('index/', views.a)
]
The
a
is the function inside of your views.py, kindly change it if ever that you use other function name. Next one is go to your main of your project which is theProjectName
folder or the same name as your Project, and paste this tourls.py
"""
URL configuration for DjangoProject project.
The `urlpatterns` list routes URLs to views. For more information please see:
https://docs.djangoproject.com/en/4.2/topics/http/urls/
Examples:
Function views
1. Add an import: from my_app import views
2. Add a URL to urlpatterns: path('', views.home, name='home')
Class-based views
1. Add an import: from other_app.views import Home
2. Add a URL to urlpatterns: path('', Home.as_view(), name='home')
Including another URLconf
1. Import the include() function: from django.urls import include, path
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
"""
from django.contrib import admin
from django.urls import path, include
urlpatterns = [
path('admin/', admin.site.urls),
path('hello/', include("DjangoApp.urls"))
]
The default code of this file is:
"""
URL configuration for DjangoProject project.
The `urlpatterns` list routes URLs to views. For more information please see:
https://docs.djangoproject.com/en/4.2/topics/http/urls/
Examples:
Function views
1. Add an import: from my_app import views
2. Add a URL to urlpatterns: path('', views.home, name='home')
Class-based views
1. Add an import: from other_app.views import Home
2. Add a URL to urlpatterns: path('', Home.as_view(), name='home')
Including another URLconf
1. Import the include() function: from django.urls import include, path
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
"""
from django.contrib import admin
from django.urls import path
urlpatterns = [
path('admin/', admin.site.urls),
]
You may also use it as the landing page of the website, by latting the path as '' or look like this format:
path('', include("DjangoApp.urls"))
, same as the urls.py of yourProjectApp
, just clear the path name. Then go to the settings.py and inside ofINSTALLEDAPPS
just add a new string same as the ProjectApp. Here's the example of before and after code:
Before
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
]
After
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'DjangoApp',# In imports
from django.shortcuts import render
from .models import user
# In the part of function and defs
def fetchUser(req):
# This will get the parameterr from the url where we will going
# to modify a data, example is /user?username=RyannKim327
usr = user.objects.get(username=req.GET.get("username"))
return render(req, "getData.html", {
"data": usr
})
]
To run this project, kindly execute this to your terminal
python manage.py runserver
Then you will see a link
http://127.0.0.1:8000
, click that and go to the url. You may see that your website doesn't look like what you did, the thing you need to do is to go to the url:http://127.0.0.1:8000/hello/index/
to see the results.
First is you need to create a folder name
templates
inside of yourProjectApp
. Inside of it, create a sample html, for exampleindex.html
. Next is go to yourviews.py
inside of yourProjectrApp
, and add this is the comparison of code on your file.
Before
from django.shortcuts import render
from django.http import HttpResponse
# Create your views here.
def a(request):
return HttpResponse("<h3>Hello World</h3>")
After
from django.shortcuts import render
from django.http import HttpResponse
# Create your views here.
def a(request):
return HttpResponse("<h3>Hello World</h3>")
def b(request):
return render(request, 'index.html')
Note: You may still change the function name based on what you want, I use a and b functions because I'm lazy to think some variable names. Now, after you've done that, go to your
urls.py
inside of yourProjectApp
and add this inside of yoururlpatterns
path('html/', views.b)
So meaning to say, it may looks like this now.
from django.http import path
from . import views
urlpatterns = [
path('index/', views.a)
path('html/', views.b)
]
So I actually forgot how, that's why I tried some trial and errors, and now, it works. First is you need to create a new folder, outside of your
ProjectApp
, but inside of yourProjectName
, and named itstatic
. In this name, Django will easily recognized the folder name. Next is create some resources there like your css. After you add your resources there, go to your html file, inside of thetemplate
folder on yourProjectApp
, and add this line to the top of the code on in line one:
{% load static %}
The sample use of static in including some resources such as image is like this
<link rel="stylesheet" type="text/css" href="{% static '/css/my.css' %}">
<img src="{% static '/img/my.png' %}">
The first line is for css, while the another line is for images, same with audios and videos, the
/css/
and/img/
signifies as the folder name inside of the static folder. Next one is go to thesettings.py
inside ofProjectName
or what we call the main. Look for theSTATIC_URL
and add this lines under of it.
STATICFILES_URLS = [BASE_DIR / 'static']
STATIC_ROOT = BASE_DIR / 'static'
This line will help Django to look for static folder faster.
The one of the requirements for a system is to have a database, and to create a specific database, we need to create an admin account or what we called super user. To create a
super user
, we need first tomigrate
the Django Project by executing this command to your terminal.
python manage.py migrate
And it gives you some information, after it says a successful message, execute this to your terminal:
python manage.py createsuperuser
And once you've execute this, you need to fill up some forms, such as username, email and passwords.
Here's a way for you to create a database here in Django, but before you create a database, you need first to have a Super User. Then follow these steps. First is you need to go to your
models.py
inside of yourProject App
which is also our component. You may see these code:
from django.db import models
# Create your models here.
Here's where you need to go through. Create a class, which represents as your table name, so if you want to creata a table name called
user
use user as class name, just like this example.
from django.db import models
# Create your models here.
class user(models.Model):
# Then add some column name here such as
username = models.CharField(max_length=25)
email = models.CharField(max_length=50)
password = models.CharField(max_length=100)
To understand this code, here's the sample result if this in
SQL
CREATE TABLE user(
username VARCHAR(30),
email VARCHAR(50),
password VARCHAR(100),
)
In addition, you may also use the defaults in Django for password by importing forms from django and using of forms.PasswordInput, here's the example
from django.db import models
from django import forms
# Create your models here.
class user(models.Model):
# Then add some column name here such as
username = models.CharField(max_length=25)
email = models.CharField(max_length=50)
password = models.CharField(max_length=100, widget=forms.PasswordInput)
Next is, you need to include the model into your djangoapp, just go to admin.py and add
admin.site.register(yourmodel)
Here's the example
# From these code
from django.contrib import admin
# Register your models here.
# ------------------------------- #
# To this code
from django.contrib import admin
from .models import *
# Register your models here.
admin.site.register(user)
makemigrations
in Django is use to packaging up all the models in Django. Models defines as the database in Django. So after you create a models in python which can be found here, you need to execute it so that your database will be updated too.
python manage.py makemigrations
So, for you who want to see the database clear, just go to
http://127.0.0.1:8080/admin/
or to your localhost admin, and login your credentials used in superuser. Then you may now see the tables existed, as well as the data you have.
Since we use the
user
Models here's the sample how do we going to add data with Django. In views.py. add these things inside, but not in literal, meaning read the comments where the code need to be inserter.
# In imports
from .models import user
# In the part of defs example is
def addUser(req):
usr = user.objects.create(username="Your username", email="[email protected]", password="sample password")
usr.save()
Take note that the parameters used here must be the data or columns you added on your Models
# In imports
from django.shortcuts import render
from .models import user
# In the part of function and defs
def fetchUser(req):
# This will get the parameterr from the url where we will going
# to modify a data, example is /user?username=RyannKim327
usr = user.objects.get(username=req.GET.get("username"))
return render(req, "getData.html", {
"data": usr
})
This is just an example to fetch a data, to include this into your templates, you may use also
{% %}
for blocks and{{ }}
for prints.
# In imports
from django.shortcuts import render
from .models import user
# In the part of function and defs
def fetchUser(req):
# This will get the parameterr from the url where we will going
# to modify a data, example is /user?username=RyannKim327
usr = user.objects.filter(email=req.GET.get("email"))
return render(req, "fetchData.html", {
"data": usr
})
Empty section
# In imports
from .models import user
# In the part of function and defs
def updateUser(req):
# This is just an example fetching a data from a form
if req.method == "POST":
# This will get the parameterr from the url where we will going
# to modify a data, example is /user?username=RyannKim327
usr = user.objects.get(username=req.GET.get("username"))
usr.email = req.POST.get("email")
usr.password = req.POST.get("password")
usr.save()
return HttpResponse("<h1>Done</h1>")
Remember, you need first to look for the information you want to modify, it is just search process, then modify it, by re-initiating it and save.
# In imports
from .models import user
# In the part of function and defs
def deleteUser(req):
# This will get the parameterr from the url where we will going
# to modify a data, example is /user?username=RyannKim327
usr = user.objects.get(username=req.GET.get("username"))
usr.delete()
return HttpResponse("<h1>Done</h1>")
Remember, you need to add some confirmation process into your frontend, once you delete this something like this, the data will be permanently remove.
The code below is just an example of the template, containing the data.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Welcome user</title>
</head>
<body>
<div>
<div class="header">
<h3>Welcome admin</h3>
</div>
<div>
<div>
<h3 style="margin-bottom: .5rem;">Employee Lists</h3>
</div>
<ol>
{% if data %}
{% for i in data %}
<li>
<span onclick="location.href = 'modify?username={{ i.username }}'">{{ i.email }}</span>
</li>
{% endfor %}
{% else %}
<p style="text-align: center;">There's no data added here</p>
{% endif %}
</div>
</ol>
</div>
</body>
</html>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Welcome user</title>
</head>
<body>
<div>
<div class="header">
<h3>Welcome admin</h3>
<nav>
<ul>
<li onclick="location.href='/add-user'">Add new Employee</li>
</ul>
</nav>
</div>
<div>
<div>
<h3 style="margin-bottom: .5rem;">Employee Lists</h3>
</div>
<ol>
{% if data %}
{% for i in data %}
<li>
<span onclick="location.href = 'delete?username={{ i.username }}'">{{ i.email }}</span>
</li>
{% endfor %}
{% else %}
<p style="text-align: center;">There's no data added here</p>
{% endif %}
</div>
</ol>
</div>
</body>
</html>
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Add new User</title>
</head>
<body>
<div class="base">
<form method="POST" action="/add-user">
{% csrf_token %}
<h3 style="text-align: center; width: 100%; margin-bottom: 1.25rem;">Add New Employee</h3>
<label for="username"><span>Username:<sup>*</sup></span> <input type="text" name="username" id="username"></label>
<label for="email">Email: <input type="email" name="email" id="email"> </label>
<label for="password"><span>Password:<sup>*</sup></span> <input type="password" name="password" id="password"></label>
<div>
<input type="submit" value="Add new user">
</div>
</form>
</div>
</body>
</html>
In deployment, such as in PythonAnywhere, you need to setup the settings here. So first, go to your
settings.py
, you may found it into your project. Look forALLOWED_HOSTS = []
and add a value "*". So the example here is
# Before
ALLOWED_HOSTS = []
# After
ALLOWED_HOSTS = ["*"]
If you notice the the
admin
page has no design, kindly installwhitenoise
and modify again thesettings.py
underMIDDLEWARES
# Before
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
# AFTER
MIDDLEWARE = [
'whitenoise.middleware.WhiteNoiseMiddleware',
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
Then lastly is to add these after the
STATIC_URL
STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'
This program is not yet finish, I still in a way of learning, that's why I've done this like day by day. Big thanks to
Mr. Leonard Andrew Mesiera
for helping us to learn this framework and providing some time to teach us. Also onCodeWithMosh
's youtube channel. Special mention for sirJohn Rovie Balingbing
for teaching us with his subject WS101. Also toStackless Tech
for the solution of aving no design in pythonanywhere