Geek Slack

Start creating your course and become a part of GeekSlack.

Course Content
Django – Fundamentals
This chapter introduces the core concepts of Django applications, views, routing, and templates, forming the foundation for building dynamic web applications.
0/5
Django – Models and Databases
This chapter explores Django's Object-Relational Mapping (ORM), a powerful feature that allows you to interact with databases using Python objects instead of raw SQL. You'll learn how to define models, perform database migrations, and work with data efficiently.
0/7
Django – Forms and User Input
This chapter focuses on how to handle user input in Django applications using forms. You will learn how to create forms, validate data, process and render forms, and use models to create forms automatically. Additionally, you will explore handling file uploads, including saving and managing media files.
0/9
Django – Admin
The Django Admin panel is one of the most powerful features of Django, allowing developers and site administrators to manage content and data seamlessly through a web interface. This chapter explores advanced features of Django Admin, focusing on customization, registration of models, customizing the display and filtering, adding actions, and creating custom admin templates.
0/7
Django – Advanced Views and URL Handling
This chapter explores advanced techniques for handling views, URLs, and middleware in Django. You'll gain a deep understanding of Class-Based Views (CBVs) and how they compare to Function-Based Views (FBVs), learn about organizing URLs effectively for large projects, and dive into middleware: a key component for processing requests and responses globally.
0/6
Django – User Authentication and Authorization
User authentication and authorization are crucial aspects of modern web applications. Django provides a comprehensive, built-in system for handling user authentication, allowing developers to easily manage user registration, login, password management, and access control. This chapter covers advanced techniques in managing users, roles, permissions, and custom user models in Django.
0/7
Django – Static and Media Files
In Django, handling static and media files efficiently is an essential aspect of web development. Static files (e.g., JavaScript, CSS, images) are files that do not change during runtime, while media files (e.g., user-uploaded files like photos, documents) are dynamic and may change or be added over time. This chapter explores how to manage both static and media files in Django, including their configuration for development and production environments.
0/3
Django – Testing and Debugging
Testing and debugging are critical skills for building robust, reliable Django applications. This chapter covers strategies to debug Django applications effectively, common errors and their fixes, and writing comprehensive tests using Django's built-in testing framework.
0/6
Django – REST Framework (Optional Advanced Section)
Django REST Framework (DRF) is a powerful and flexible toolkit for building Web APIs with Django. This chapter introduces you to REST principles, guides you through setting up DRF, and explores advanced concepts like serializers, views, routers, and authentication mechanisms.
0/6
Django – Deployment
Deploying a Django application ensures that your project is accessible to users over the internet. This chapter covers the steps to prepare your application for deployment, tools and configurations for different deployment scenarios, and best practices for securing Django applications in a production environment.
0/6
Django Tutorial
About Lesson

Media files are files uploaded by users (e.g., images, PDFs, videos). Django doesn’t automatically serve media files in development or production, but it provides an easy way to handle media uploads and configure settings to store and access these files.

Configuring Media Files in Django

You need to specify two important settings in your settings.py to manage media files:

  • MEDIA_URL: The URL path for accessing media files.
  • MEDIA_ROOT: The file system path where uploaded media files will be stored.

# settings.py

# URL to access media files
MEDIA_URL = '/media/'

# Directory to store uploaded media files
MEDIA_ROOT = BASE_DIR / "media"
  • MEDIA_URL: This is the base URL that Django will use to serve media files (e.g., /media/).
  • MEDIA_ROOT: This is the absolute file system path where media files will be stored, such as user-uploaded images and documents.

Example of Media File in Django Template

  <img src="{{ user.profile_picture.url }}" alt="Profile Picture">
  

Handling File Uploads in Django

Django provides forms to handle file uploads. The model field used to store uploaded files is FileField or ImageField for images.

Example of Model with Media File:


from django.db import models

class Profile(models.Model):
    user = models.OneToOneField(User, on_delete=models.CASCADE)
    profile_picture = models.ImageField(upload_to='profile_pics/', null=True, blank=True)
  • The upload_to argument in the ImageField specifies the subdirectory where files will be uploaded, relative to the MEDIA_ROOT directory.

Handling File Upload in Forms

You need to include an HTML form with enctype="multipart/form-data" to allow users to upload files.

Example of Form for Uploading Files:


from django import forms
from .models import Profile

class ProfileForm(forms.ModelForm):
    class Meta:
        model = Profile
        fields = ['profile_picture']

# In the view:
def upload_profile_picture(request):
    if request.method == 'POST':
        form = ProfileForm(request.POST, request.FILES)
        if form.is_valid():
            form.save()
    else:
        form = ProfileForm()
    return render(request, 'profile/upload_picture.html', {'form': form})

Example of Template for Uploading Files:


  <form method="POST" enctype="multipart/form-data">
      {% csrf_token %}
      {{ form.as_p }}
      <button type="submit">Upload</button>
  </form>
  
  • request.FILES: This allows you to access the uploaded files in your form.
Join the conversation