suchen
HeimBackend-EntwicklungPython-TutorialAuthentifizierung und Autorisierung in Django: Django-Sitzung

Authentication and Authorization in Django: Django session

Einführung in Django-Sitzungen

In modernen Webanwendungen ist die Aufrechterhaltung des Benutzerstatus über mehrere Anfragen hinweg unerlässlich, um personalisierte Erlebnisse zu schaffen. Django vereinfacht dies mit seinem integrierten Sitzungsframework und ermöglicht es Entwicklern, Benutzerdaten sicher und effizient zu verwalten.

Die integrierten Sitzungen in Django sind für die Verwaltung von Benutzerdaten über mehrere Anfragen hinweg verantwortlich. Wenn sich Benutzer bei der Django-App anmelden, erstellt der Server eine Sitzungs-ID, die normalerweise in einem Cookie im Browser des Clients gespeichert wird. Diese Session-ID dient als Schlüssel zum Abruf der auf dem Server gespeicherten Daten und zur Zuordnung von Anfragen zu einem bestimmten Benutzer. Aus diesem Grund bleibt der Authentifizierungsstatus auf verschiedenen Seiten bestehen.


Verwendung von Session-Middleware in Django

Djangos Sitzungs-Middleware automatisiert die Sitzungsverwaltung. Es verarbeitet eingehende Anfragen zum Abrufen von Sitzungsdaten und bereitet ausgehende Antworten zum Aktualisieren oder Setzen von Sitzungscookies vor. Um zu überprüfen, ob Sitzungs-Middleware aktiviert ist, schauen Sie in Ihrer Datei „settings.py“ im Abschnitt „MIDDLEWARE“ nach:

# settings.py
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    # Other middleware
]


Arten der Sitzungsspeicherung in Django

Wir haben mehrere Möglichkeiten, Sitzungsdaten zu speichern. Abhängig von der Anwendung, die Sie erstellen möchten, hat jede davon Vor- und Nachteile.

1. Datenbankgestützte Sitzungen

Analogie: Stellen Sie sich vor, das Theater verfügt über einen sicheren Lagerraum mit Schließfächern, in dem alle Mäntel aufbewahrt werden. Jedem Schließfach wird eine eindeutige Nummer zugewiesen, die mit der Nummer auf Ihrem Ticket übereinstimmt. Wenn Sie mit Ihrem Ticket zurückkommen, sucht der Mitarbeiter die Schließfachnummer in einem Logbuch und holt Ihren Mantel ab.

Datenbankgestützte Sitzungen speichern Sitzungsdaten auf einem Datenbankserver. So bleiben vertrauliche Informationen wie Benutzereinstellungen, Anmeldestatus und Warenkorbdetails sicher im Backend gespeichert. Diese Art von Sitzung ist möglicherweise sicherer, verursacht jedoch einige Unannehmlichkeiten, wenn es um den Schreib- und Lesevorgang geht. Datenbankgestützte Sitzungen sind im Vergleich zu Cache-gestützten Sitzungen langsamer. Wenn Sie also eine Anwendung mit hohem Datenverkehr erstellen, sollten Sie noch einmal darüber nachdenken. Das Speichern von Sitzungen in der Datenbank kann die Belastung der Datenbank erhöhen und sich bei unsachgemäßer Verwaltung auf die Gesamtleistung auswirken.

Wenn Sie eine datenbankgestützte Sitzung verwenden möchten, müssen Sie django.contrib.sessions zu Ihrer INSTALLED_APPS-Einstellung hinzufügen. Bitte stellen Sie sicher, dass Sie manage.py migrate ausführen, um die einzelne Datenbanktabelle zu installieren, in der Sitzungsdaten gespeichert werden.

2. Dateibasierte Sitzungen

Analogie: In diesem Fall wird jeder Mantel in einem anderen, beschrifteten Schließfach in einem großen Raum im hinteren Teil des Theaters aufbewahrt. Jedes Schließfach verfügt über einen eindeutigen Anhänger oder eine Datei mit den Manteldetails. Wenn Sie Ihr Ticket vorzeigen, geht der Mitarbeiter in den Umkleideraum, findet den entsprechenden Anhänger und holt Ihren Mantel ab.

Dateibasierte Sitzungen nutzen das Dateisystem des Servers, um Sitzungsdaten zu speichern. Dies bedeutet, dass jede Benutzersitzung in einer separaten Datei auf dem Server gespeichert wird. Standardmäßig speichert Django Sitzungsdateien im Verzeichnis django_session unter /tmp (auf Unix-basierten Systemen) oder in einem in den Django-Einstellungen angegebenen Verzeichnis.

Um dateibasierte Sitzungen zu aktivieren, setzen Sie SESSION_ENGINE in Ihrer Datei „settings.py“ auf django.contrib.sessions.backends.file.

# settings.py
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    # Other middleware
]

3. Cache-gestützte Sitzungen

Analogie: Hier nutzt das Theater eine provisorische Garderobe in der Nähe des Eingangs, wo Mäntel nur kurz aufbewahrt werden. Dadurch ist das Abholen von Mänteln sehr schnell möglich, aber wenn das Regal voll ist, können die ältesten Mäntel in ein Zweitlager verschoben oder ganz entfernt werden.

Bei dieser Art der Sitzungsspeicherung speichert ein Caching-System (wie Memcached oder Redis) Sitzungsdaten. Das Speichern von Sitzungen im Speicher-Caching hilft Anwendungen mit hohem Datenverkehr oder Anwendungen, die schnelle Reaktionszeiten erfordern, da der Schreib- oder Lesevorgang sehr schnell abläuft.

Um Cache-gestützte Sitzungen zu verwenden, konfigurieren Sie die Einstellung SESSION_ENGINE in Ihrer Datei „settings.py“. Sie müssen auch den Cache konfigurieren, je nachdem, welchen Cache-Speicher Sie verwenden.

# settings.py
SESSION_ENGINE = 'django.contrib.sessions.backends.file'  # Use file-based session storage
SESSION_FILE_PATH = '/path/to/session/files/'  # Specify a directory for session files (optional)

Alternativ können Sie django.contrib.sessions.backends.cached_db verwenden, das Sitzungsdaten sowohl im Cache als auch in der Datenbank speichert und auf die Datenbank zurückgreift, wenn der Cache nicht verfügbar ist.

Die besten Vorteile dieser Art von Sitzung sind Skalierbarkeit und Geschwindigkeit. Cache-gestützte Sitzungen sind nicht nur schnell, da Daten im Speicher gespeichert werden, sondern reduzieren auch die Belastung der Datenbanksitzung. Daten können von mehreren Servern gemeinsam genutzt werden, was die Einrichtung mehrerer Server ermöglicht.

4. Signierte Cookie-Sitzungen

Analogie: Anstatt Ihren Mantel aufzubewahren, erlaubt Ihnen das Theater, ihn mit sich herumzutragen, erfordert aber einen speziellen Stempel auf der Eintrittskarte, der bestätigt, dass es sich um Ihren Mantel handelt. Sie bringen den Mantel (Sitzungsdaten) mit und jedes Mal, wenn Sie das Theater betreten, überprüft der Mitarbeiter den Stempel auf der Eintrittskarte, um sicherzustellen, dass diese nicht manipuliert wurde.

Signierte Cookie-Sitzungen in Django speichern Sitzungsdaten direkt im Browser des Clients in einem signierten und verschlüsselten Cookie, anstatt sie auf der Serverseite (Datenbank oder Cache) zu speichern.

Um signierte Cookie-Sitzungen zu aktivieren, legen Sie SESSION_ENGINE in der Datei „settings.py“ von Django fest, um das signierte Cookie-Backend zu verwenden:

# settings.py
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    # Other middleware
]

Signierte Cookie-Sitzungen reduzieren die Serverlast und geben Serverressourcen frei. Aufgrund der Größenbeschränkung für Cookies (ca. 4 KB) sind signierte Cookie-Sitzungen jedoch nicht zum Speichern großer Mengen an Sitzungsdaten geeignet. Größere Cookie-Größen können zu langsameren Anfragen führen, da die Cookie-Daten bei jeder Anfrage gesendet werden.


Sitzungskonfigurationseinstellungen

Django bietet mehrere Einstellungen zum Konfigurieren des Sitzungsverhaltens:

  • SESSION_COOKIE_AGE: Legt die Ablaufzeit der Sitzung fest (in Sekunden).

  • SESSION_COOKIE_SECURE: Erfordert die Übertragung von Sitzungen über HTTPS.

  • SESSION_EXPIRE_AT_BROWSER_CLOSE: Beendet die Sitzung, wenn der Browser geschlossen wird.

  • SESSION_COOKIE_HTTPONLY: Beschränkt den JavaScript-Zugriff auf Sitzungscookies und erhöht so die Sicherheit.

Diese Einstellungen helfen dabei, das Sitzungsverhalten an spezifische Anwendungsanforderungen anzupassen. Weitere Informationen zur Sitzungskonfiguration finden Sie in der Django-Dokumentation.


Implementierung von Sitzungen in Django-Ansichten

Um mit Sitzungen in Django-Ansichten zu interagieren, verwenden Sie das request.session-Objekt, das sich wie ein Wörterbuch verhält. Hier sind einige grundlegende Vorgänge:

Datenspeicherung:

# settings.py
SESSION_ENGINE = 'django.contrib.sessions.backends.file'  # Use file-based session storage
SESSION_FILE_PATH = '/path/to/session/files/'  # Specify a directory for session files (optional)

Daten abrufen:

# settings.py
SESSION_ENGINE = 'django.contrib.sessions.backends.cache'  # For caching session storage
SESSION_CACHE_ALIAS = 'default'  # Specify the cache alias if needed (e.g., 'redis' or 'memcached')

# Cache configuration (example with Redis)
CACHES = {
    'default': {
        'BACKEND': 'django_redis.cache.RedisCache',
        'LOCATION': 'redis://127.0.0.1:6379/1',  # Redis URL
        'OPTIONS': {
            'CLIENT_CLASS': 'django_redis.client.DefaultClient',
        }
    }
}

Daten löschen:

# settings.py
SESSION_ENGINE = 'django.contrib.sessions.backends.signed_cookies'
SECRET_KEY = 'your-secret-key'  # Make sure this key is kept secure and unique for your app

Sitzungen werden häufig verwendet, um den Anmeldestatus von Benutzern zu verfolgen. So implementieren Sie ein einfaches Anmeldesystem mithilfe von Sitzungen:

request.session['username'] = 'Harry Potter'

Es gibt immer noch viele Methoden für Sitzungen in Django-Ansichten. Eine vollständige Liste finden Sie in der Django-Dokumentation.


Best Practice für Sitzungen

Django löscht regelmäßig abgelaufene Sitzungen. Sie können die Häufigkeit anpassen, indem Sie den Sitzungsbereinigungsprozess konfigurieren oder Verwaltungsbefehle wie django-admin clearsessions ausführen.

Vermeiden Sie das Speichern großer Datenmengen in Sitzungen, da dies die Serverlast erhöhen und die Antwortzeiten verlangsamen kann. Aktivieren Sie abschließend sichere Cookies, HttpOnly und HTTPS-Einstellungen, um Sitzungsdaten zu schützen.


Abschluss

Djangos Sitzungsframework ist leistungsstark, flexibel und sicher und erleichtert die Implementierung der Sitzungsverwaltung in Ihren Webanwendungen. Mit der richtigen Konfiguration und sicheren Vorgehensweisen können Sie Django-Sitzungen nutzen, um effiziente, personalisierte Benutzererlebnisse zu schaffen und gleichzeitig eine robuste Sicherheit aufrechtzuerhalten.

Das obige ist der detaillierte Inhalt vonAuthentifizierung und Autorisierung in Django: Django-Sitzung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Der Hauptzweck von Python: Flexibilität und BenutzerfreundlichkeitDer Hauptzweck von Python: Flexibilität und BenutzerfreundlichkeitApr 17, 2025 am 12:14 AM

Die Flexibilität von Python spiegelt sich in Multi-Paradigm-Unterstützung und dynamischen Typsystemen wider, während eine einfache Syntax und eine reichhaltige Standardbibliothek stammt. 1. Flexibilität: Unterstützt objektorientierte, funktionale und prozedurale Programmierung und dynamische Typsysteme verbessern die Entwicklungseffizienz. 2. Benutzerfreundlichkeit: Die Grammatik liegt nahe an der natürlichen Sprache, die Standardbibliothek deckt eine breite Palette von Funktionen ab und vereinfacht den Entwicklungsprozess.

Python: Die Kraft der vielseitigen ProgrammierungPython: Die Kraft der vielseitigen ProgrammierungApr 17, 2025 am 12:09 AM

Python ist für seine Einfachheit und Kraft sehr beliebt, geeignet für alle Anforderungen von Anfängern bis hin zu fortgeschrittenen Entwicklern. Seine Vielseitigkeit spiegelt sich in: 1) leicht zu erlernen und benutzten, einfachen Syntax; 2) Reiche Bibliotheken und Frameworks wie Numpy, Pandas usw.; 3) plattformübergreifende Unterstützung, die auf einer Vielzahl von Betriebssystemen betrieben werden kann; 4) Geeignet für Skript- und Automatisierungsaufgaben zur Verbesserung der Arbeitseffizienz.

Python in 2 Stunden am Tag lernen: Ein praktischer LeitfadenPython in 2 Stunden am Tag lernen: Ein praktischer LeitfadenApr 17, 2025 am 12:05 AM

Ja, lernen Sie Python in zwei Stunden am Tag. 1. Entwickeln Sie einen angemessenen Studienplan, 2. Wählen Sie die richtigen Lernressourcen aus, 3. Konsolidieren Sie das durch die Praxis erlernte Wissen. Diese Schritte können Ihnen helfen, Python in kurzer Zeit zu meistern.

Python gegen C: Vor- und Nachteile für EntwicklerPython gegen C: Vor- und Nachteile für EntwicklerApr 17, 2025 am 12:04 AM

Python eignet sich für eine schnelle Entwicklung und Datenverarbeitung, während C für hohe Leistung und zugrunde liegende Kontrolle geeignet ist. 1) Python ist einfach zu bedienen, mit prägnanter Syntax, und eignet sich für Datenwissenschaft und Webentwicklung. 2) C hat eine hohe Leistung und eine genaue Kontrolle und wird häufig bei der Programmierung von Spielen und Systemen verwendet.

Python: zeitliches Engagement und LerntempoPython: zeitliches Engagement und LerntempoApr 17, 2025 am 12:03 AM

Die Zeit, die zum Erlernen von Python erforderlich ist, variiert von Person zu Person, hauptsächlich von früheren Programmiererfahrungen, Lernmotivation, Lernressourcen und -methoden und Lernrhythmus. Setzen Sie realistische Lernziele und lernen Sie durch praktische Projekte am besten.

Python: Automatisierung, Skript- und AufgabenverwaltungPython: Automatisierung, Skript- und AufgabenverwaltungApr 16, 2025 am 12:14 AM

Python zeichnet sich in Automatisierung, Skript und Aufgabenverwaltung aus. 1) Automatisierung: Die Sicherungssicherung wird durch Standardbibliotheken wie OS und Shutil realisiert. 2) Skriptschreiben: Verwenden Sie die PSUTIL -Bibliothek, um die Systemressourcen zu überwachen. 3) Aufgabenverwaltung: Verwenden Sie die Zeitplanbibliothek, um Aufgaben zu planen. Die Benutzerfreundlichkeit von Python und die Unterstützung der reichhaltigen Bibliothek machen es zum bevorzugten Werkzeug in diesen Bereichen.

Python und Zeit: Machen Sie das Beste aus Ihrer StudienzeitPython und Zeit: Machen Sie das Beste aus Ihrer StudienzeitApr 14, 2025 am 12:02 AM

Um die Effizienz des Lernens von Python in einer begrenzten Zeit zu maximieren, können Sie Pythons DateTime-, Zeit- und Zeitplanmodule verwenden. 1. Das DateTime -Modul wird verwendet, um die Lernzeit aufzuzeichnen und zu planen. 2. Das Zeitmodul hilft, die Studie zu setzen und Zeit zu ruhen. 3. Das Zeitplanmodul arrangiert automatisch wöchentliche Lernaufgaben.

Python: Spiele, GUIs und mehrPython: Spiele, GUIs und mehrApr 13, 2025 am 12:14 AM

Python zeichnet sich in Gaming und GUI -Entwicklung aus. 1) Spielentwicklung verwendet Pygame, die Zeichnungen, Audio- und andere Funktionen bereitstellt, die für die Erstellung von 2D -Spielen geeignet sind. 2) Die GUI -Entwicklung kann Tkinter oder Pyqt auswählen. Tkinter ist einfach und einfach zu bedienen. PYQT hat reichhaltige Funktionen und ist für die berufliche Entwicklung geeignet.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

VSCode Windows 64-Bit-Download

VSCode Windows 64-Bit-Download

Ein kostenloser und leistungsstarker IDE-Editor von Microsoft