Django Technical Paper
Siddharth Shanker
Posted on June 16, 2023
Django is a high level Python web framework that enables rapid development of secure and maintainable websites.
Settings file
What is secret key ?
- Django secret key is used to provide cryptographic signing. This key is mostly used to sign session cookies, create hashes and tokens for sensitive information like csrf tokens or password reset tokens. ### What are default Django apps inside it ? Are there more ?
- django.contrib.admin - Provides Django administration interface, which allows users to manage and update application's data.
- django.contrib.auth - Provides the authentication system, including user modes, login/logout views and password management.
- django.contrib.contenttypes - Provides the track of all the models along with a high-level, generic interface for working with our models.
- django.contrib.sessions- This app lets us store and retrieve session data for each visitor to your site.
- django.contrib.messages - This framework allows us to temporarily store messages in one request and retrieve them for display in subsequent request.
- django.contrib.staticfiles - Helps in managing static files (eg- CSS, JavaScript) in Django project and serves them during development.
These are default installed apps, other apps that can be added to our Django project include:-
- sites - Provides framework for managing multiple sites
- sitemaps - Helps in generating XML sitemaps for Django site
- humanize Provides a set of template filters that help in formatting data in a more human readable way.
- redirects app allows to manage URL redirects
- gis- Provides support for geographic data and includes spatial fields, spatial indexes. ### What is middleware ? What are different kinds of middleware ?
- Defined as classes with methods that handle the processing of requests and responses.
- Middlewares can perform authentication, session management, content encoding, URL redirection and more. List of middlewares :-
-
django.middleware.security.SecurityMiddleware
: This middleware adds several security-related HTTP headers to the responses, such as enforcing HTTPS, preventing click-jacking attacks, and setting content type options.
django.middleware.csrf.CsrfViewMiddleware
: This middleware provides protection against Cross-Site Request Forgery (CSRF) attacks by adding and verifying CSRF tokens in POST requests.django.contrib.sessions.middleware.SessionMiddleware
: This middleware enables session management by storing session data in cookies or a database, and it makes the session data available in request objects.django.contrib.auth.middleware.AuthenticationMiddleware
: This middleware associates authenticated users with requests by adding theUser
object to the request.django.contrib.messages.middleware.MessageMiddleware
: This middleware enables the messaging framework, which allows the temporary storage of messages that can be displayed to the user on subsequent requests.django.middleware.locale.LocaleMiddleware
: This middleware handles language selection and translation by detecting the user's preferred language and activating the corresponding translation.django.middleware.common.CommonMiddleware
: This middleware performs common operations, such as URL rewriting, response gzip compression, and appending a slash to the end of URLs.
CSRF
- Stands for Cross site request forgery.
- CSRF attacks allow a malicious user to execute actions using the credentials of another user without that user's knowledge or consent.
- Django provides CSRF tokens for security.
- When a user visits a Django site, a CSRF token is generated ands stored in their sessions or cookies.
- When the server receives POST request it verifies the CSRD token, if they match the POST request is determined as valid otherwise rejected.
- CsrfViewMiddleware is responsible for generating and validating tokens.
- In HTML templates we use { % csrf_token %}
XSS
- Stands for Cross-Site Scripting
- Type of security vulnerability that allows attackers to inject malicious scripts into web pages viewed by other users.
- Occurs when web application doesn't verify user input.
- Code is executed by the victims and lets attackers bypass access controls and impersonate users. ### Click Jacking
- Here the attacker cons the victim by making them perform clicking action on a seemingly harmless element or perform any action on a web page without their consent.
- This is done by deceiving the victim with the help of interface.
- Eg:- Victim accesses a decoy website and clicks on a button to win a prize. Unknowingly, they have been deceived by an attacker into pressing an alternative hidden button and this results in the payment of an account on another site.
WSGI
- Pronounced as "whiskey" :P
- It is a specification that defines a simple and universal interface between web servers and web applications or frameworks.
- Provides a set of rules and guidelines for how a web server should communicate with a web application or framework.
- The communication between the server and the application/framework happens through a callable object called the "application" or "app" object. This object is responsible for handling incoming requests and returning appropriate responses.
Models
Models.py
- File contains the definition of the application's data models using Django's Object-Relational Mapping (ORM) system. Models define the structure and behavior of database tables, allowing you to interact with data in a Pythonic way.
Field Options
-
null -
If
True
, Django will store empty values asNULL
in the database. Default isFalse
. -
blank -
If
True
, the field is allowed to be blank. Default isFalse
. - choices - A tuple of tuples or a list of tuples, where each tuple represents a choice option. The first element of each tuple is the value stored in the database, and the second element is the human-readable label displayed to the user.
default -
The default value for the field. This can be a value or a callable object. If callable it will be called every time a new object is created.error_messages -
Theerror_messages
argument lets you override the default messages that the field will raise. Pass in a dictionary with keys matching the error messages you want to override.primary_key -
IfTrue
, this field is the primary key for the model.
If you don’t specifyprimary_key=True
for any field in your model, Django will automatically add a field to hold the primary keyunique -
IfTrue
, this field must be unique throughout the table
Field Types
-
AutoField
- An IntegerField that automatically increments according to available IDs.
-
BigIntegerField
- A 64-bit integer, much like an IntegerField except that it is guaranteed to fit numbers from
-9223372036854775808
to9223372036854775807
.
- A 64-bit integer, much like an IntegerField except that it is guaranteed to fit numbers from
-
BinaryField
- A field to store raw binary data. It can be assigned bytes bytearray, or memoryview.
By default,
BinaryField
sets editable toFalse
, in which case it can’t be included in a ModelForm.
- A field to store raw binary data. It can be assigned bytes bytearray, or memoryview.
By default,
-
BooleanField
- A true/false field.
-
CharField
- A string field, for small- to large-sized strings.
- has extra arguments:
- .max_length - The maximum length (in characters) of the field. The max_length is enforced at the database level
-
DateField
- Field type used to store and handle date values. It typically provides functionalities to parse, format, and validate dates.
-
DecimalField
- Field type used to store decimal numbers with a fixed precision and scale. It is often used when precise decimal calculations are required, such as in financial applications.
FileField
Field type used to handle file uploads. It allows users to upload files, and the FileField stores the file on the server and keeps track of its location or other relevant information.
EmailField
Field type used for email address input and validation. It typically ensures that the entered value follows the format of an email address.
JSONField
Field type used to store JSON (JavaScript Object Notation) data. It allows you to store JSON objects or arrays in a database field and provides functionalities to access and manipulate the JSON data.
TextField
Field type used to store large amounts of text data. It is suitable for storing long-form textual content, such as blog posts or user comments, where a predefined limit on the text length is not necessary.
UUIDField
Field type used to store universally unique identifiers (UUIDs). UUIDs are 128-bit identifiers that are unique across all devices and systems, making them suitable for various identification purposes.
SlugField
Field type used to generate and store a URL-friendly version of a string. It is commonly used in web development frameworks to create human-readable and search engine-friendly URLs based on other field values.
## Django ORM
>>> from iplapp.models import *
>>> Matches.objects.all()
<QuerySet [<Matches: Matches object (1)>, <Matches: Matches object (2)>, <Matches: Matches object (3)>, <Matches: Matches object (4)>, <Matches: Matches object (5)>, <Matches: Matches object (6)>, <Matches: Matches object (7)>, <Matches: Matches object (8)>, <Matches: Matches object (9)>, <Matches: Matches object (10)>, <Matches: Matches object (11)>, <Matches: Matches object (12)>, <Matches: Matches object (13)>, <Matches: Matches object (14)>, <Matches: Matches object (15)>, <Matches: Matches object (16)>, <Matches: Matches object (17)>, <Matches: Matches object (18)>, <Matches: Matches object (19)>, <Matches: Matches object (20)>, '...(remaining elements truncated)...']>
>>>
>>>
>>>
>>> Matches.objects.aggregate(count=Count('id'))
Traceback (most recent call last):
File "<console>", line 1, in <module>
NameError: name 'Count' is not defined
>>> from django.models import Count
Traceback (most recent call last):
File "<console>", line 1, in <module>
ModuleNotFoundError: No module named 'django.models'
>>> from django.db.models import Count
>>> Matches.objects.aggregate(count=Count('id'))
{'count': 636}
>>>
Turning ORM to SQL in Django Shell
Run the python shell
python manage.py shell
Import models and perform ORM query
>>> from django.db.models import *
>>>
>>> query = Matches.objects.all()
>>> print(query.query)
SELECT "iplapp_matches"."id", "iplapp_matches"."season", "iplapp_matches"."city", "iplapp_matches"."date", "iplapp_matches"."team1", "iplapp_matches"."team2", "iplapp_matches"."toss_winner", "iplapp_matches"."toss_decision", "iplapp_matches"."result", "iplapp_matches"."dl_applied", "iplapp_matches"."winner", "iplapp_matches"."win_by_runs", "iplapp_matches"."win_by_wickets", "iplapp_matches"."player_of_match", "iplapp_matches"."venue", "iplapp_matches"."umpire1", "iplapp_matches"."umpire2", "iplapp_matches"."umpire3" FROM "iplapp_matches"
AGGRGATIONS:
- These are special mathematical operations that can be performed on Fields(vertically)
- The common aggrigate functions are SUM, COUNT, MIN, MAX, AVG etc
- Aggrigate functions should be imported from django models class Example
- Move to shell
>>> from app.models import ModelName
>>> from django.db.models import Count,Sum,Min,Max,Avg
>>> ModelName.objects.aggregate(Count("id"))
>>> ModelName.objects.aggregate(Sum("Attribute"))
>>> ModelName.objects.aggregate(Avg("Attribute"))
>>> ModelName.objects.aggregate(Min("Attribute"))
ANNOTATIONS
- Annotations are used to add an extra field to the query set object
Example:
>>> from app.models import ModelName
>>> from django.db.models import Count,Sum,Min,Max,Avg
>>> queryset = ModelName.objects.annotate(count = Count("id"))
- Here each queryset object will have attribute 'count'
What is a migration file? Why is it needed?
- Migrations files are generated by django when we hit command
python manage.py makemigrations # It will show the changes that it's going to make
python manage.py migrate # This will change the state of database
- django will keep track of all the changes that we do the models as a files with dependencies on each other in a migrations folder
- ORM will check for the state of database when we hit migrate .if it come accross any changes it will try to do that in the process if any interruption happens because of some migrations file missing etc, it will collapse the database.
What are SQL Transactions
- Transactions in SQL are the bundle or set of operations that are performed for one functionality.
- Transaction involves one or more database operations
- These will make sure that either all the operations are successful or non of them exicutes, so that consistency has maintained in the database
ATOMIC TRANSACTIONS
- These are the transactions that make sure the operations should be performed as a whole not individually
- Since django uses the auto save, transactions are default not atomic
- So, to make them atomic, we can use transactions from django.db
from django.db import transaction
@transaction.atomic
def viewfunc(request):
# This code executes inside a transaction.
do_stuff()
- Using Context manager
def view(self, *args , **options):
with transaction.atomic():
# db operations
References
Posted on June 16, 2023
Join Our Newsletter. No Spam, Only the good stuff.
Sign up to receive the latest update from our blog.