django.contrib.auth¶
Detta dokument tillhandahåller API-referensmaterial för komponenterna i Djangos autentiseringssystem. För mer information om användningen av dessa komponenter eller hur du anpassar autentisering och auktorisering, se autentisering ämnesguide.
User modell¶
- class models.User¶
Fält¶
- class models.User
User-objekt har följande fält:- username¶
Krävs. 150 tecken eller färre. Användarnamn kan innehålla alfanumeriska tecken,
_,@,+,.och-.Den maximala längden bör vara tillräcklig för många användningsfall. Om du behöver en längre längd, använd en custom user model.
- first_name¶
Valfritt (
blank=True). 150 tecken eller färre.
- last_name¶
Valfritt (
blank=True). 150 tecken eller färre.
- email¶
Valfritt (
blank=True). E-post adress.
- password¶
Obligatoriskt. En hash av, och metadata om, lösenordet. (Django lagrar inte det råa lösenordet.) Råa lösenord kan vara godtyckligt långa och kan innehålla alla tecken. Metadata i detta fält kan markera lösenordet som oanvändbart. Se dokumentation om lösenord.
- user_permissions¶
Många-till-många-relation till
Permission
- is_staff¶
Boolesk. Tillåter att den här användaren får åtkomst till administratörsplatsen.
- is_active¶
Boolesk. Markerar detta användarkonto som aktivt. Vi rekommenderar att du sätter den här flaggan till
Falseistället för att radera konton. På så sätt går inte de utländska nycklarna sönder om dina applikationer har några utländska nycklar till användare.Detta kontrollerar inte nödvändigtvis om användaren kan logga in eller inte. Autentiseringsbackends är inte skyldiga att kontrollera flaggan
is_activemen standardbackend (ModelBackend) ochRemoteUserBackendgör det. Du kan användaAllowAllUsersModelBackendellerAllowAllUsersRemoteUserBackendom du vill tillåta inaktiva användare att logga in. I det här fallet vill du också anpassaAuthenticationFormsom används avLoginVieweftersom den avvisar inaktiva användare. Tänk på att metoderna för behörighetskontroll somhas_perm()och autentiseringen i Django admin alla returnerarFalseför inaktiva användare.
- is_superuser¶
Booleansk. Behandlar den här användaren som om den har alla behörigheter utan att tilldela någon särskild behörighet till den.
- last_login¶
En datatid för användarens senaste inloggning.
- date_joined¶
Datum/tid då kontot skapades.
Attribut¶
- class models.User
- is_authenticated¶
Skrivskyddat attribut som alltid är
True(i motsats tillAnonymousUser.is_authenticatedsom alltid ärFalse). Det här är ett sätt att se om användaren har autentiserats. Det innebär inte några behörigheter och kontrollerar inte om användaren är aktiv eller har en giltig session. Även om du normalt kommer att kontrollera detta attribut pårequest.userför att ta reda på om det har fyllts i avAuthenticationMiddleware(som representerar den för närvarande inloggade användaren), bör du veta att detta attribut ärTrueför allaUser-instanser.
- is_anonymous¶
Skrivskyddat attribut som alltid är
False. Detta är ett sätt att skilja mellan objektenUserochAnonymousUser. Generellt sett bör du föredra att användais_authenticatedframför detta attribut.
Metoder¶
- class models.User
- get_username()¶
Returnerar användarnamnet för användaren. Eftersom
User-modellen kan bytas ut bör du använda den här metoden istället för att referera till användarnamnsattributet direkt.
- get_full_name()¶
Returnerar
first_namepluslast_name, med ett mellanslag emellan.
- get_short_name()¶
Returnerar
first_name.
- set_password(raw_password)¶
Ställer in användarens lösenord till den angivna råsträngen och tar hand om lösenordets hashing. Sparar inte
User-objektet.När
raw_passwordärNone, kommer lösenordet att sättas till ett oanvändbart lösenord, som omset_unusable_password()användes.
- check_password(raw_password)¶
- acheck_password(raw_password)¶
Asynkron version:
acheck_password()Returnerar
Trueom den angivna råsträngen är rätt lösenord för användaren. (Detta tar hand om lösenordets hashing vid jämförelsen.)
- set_unusable_password()¶
Markerar användaren som att inget lösenord har angetts genom att uppdatera metadata i fältet
password. Detta är inte samma sak som att ha en tom sträng som lösenord.check_password()för den här användaren kommer aldrig att returneraTrue. Sparar inte objektetUser.Du kan behöva detta om autentiseringen för din applikation sker mot en befintlig extern källa, t.ex. en LDAP-katalog.
Begränsning av återställning av lösenord
Användare som har ett oanvändbart lösenord kommer inte att kunna begära ett e-postmeddelande om återställning av lösenord via
PasswordResetView.
- has_usable_password()¶
Returnerar
Falseomset_unusable_password()har anropats för den här användaren.
- get_user_permissions(obj=None)¶
- aget_user_permissions(obj=None)¶
Asynkron version:
aget_user_permissions()Returnerar en uppsättning behörighetssträngar som användaren har direkt.
Om
objanges returneras endast användarrättigheterna för detta specifika objekt.Changed in Django 5.2:metoden
aget_user_permissions()har lagts till.
- get_group_permissions(obj=None)¶
- aget_group_permissions(obj=None)¶
Asynkron version:
aget_group_permissions()Returnerar en uppsättning behörighetssträngar som användaren har via sina grupper.
Om
objanges returneras endast gruppbehörigheterna för detta specifika objekt.Changed in Django 5.2:metoden
aget_group_permissions()har lagts till.
- get_all_permissions(obj=None)¶
- aget_all_permissions(obj=None)¶
Asynkron version:
aget_all_permissions()Returnerar en uppsättning behörighetssträngar som användaren har, både genom grupp- och användarbehörigheter.
Om
objanges returneras endast behörigheterna för detta specifika objekt.Changed in Django 5.2:metoden
aget_all_permissions()har lagts till.
- has_perm(perm, obj=None)¶
- ahas_perm(perm, obj=None)¶
Asynkron version:
ahas_perm()Returnerar
Trueom användaren har den angivna behörigheten, där perm är i formatet"<app label>.<permission codename>". (se dokumentation om permissions). Om användaren är inaktiv kommer denna metod alltid att returneraFalse. För en aktiv superanvändare kommer denna metod alltid att returneraTrue.Om
objskickas in kommer denna metod inte att söka efter en behörighet för modellen, utan för detta specifika objekt.Changed in Django 5.2:metoden
ahas_perm()har lagts till.
- has_perms(perm_list, obj=None)¶
- ahas_perms(perm_list, obj=None)¶
Asynkron version:
ahas_perms()Returnerar
Trueom användaren har var och en av de angivna behörigheterna, där varje behörighet är i formatet"<app label>.<permission codename>". Om användaren är inaktiv returnerar denna metod alltidFalse. För en aktiv superanvändare kommer denna metod alltid att returneraTrue.Om
objanges kommer den här metoden inte att kontrollera behörigheter för modellen, utan för det specifika objektet.Changed in Django 5.2:metoden
ahas_perms()har lagts till.
- has_module_perms(package_name)¶
- ahas_module_perms(package_name)¶
Asynkron version:
ahas_module_perms()Returnerar
Trueom användaren har några behörigheter i det angivna paketet (Django-appens etikett). Om användaren är inaktiv kommer denna metod alltid att returneraFalse. För en aktiv superanvändare kommer denna metod alltid att returneraTrue.Changed in Django 5.2:metoden
ahas_module_perms()har lagts till.
- email_user(subject, message, from_email=None, **kwargs)¶
Skickar ett e-postmeddelande till användaren. Om
from_emailärNoneanvänder DjangoDEFAULT_FROM_EMAIL. Alla**kwargsskickas till det underliggandesend_mail()-anropet.
Metoder för chefer¶
- class models.UserManager¶
Modellen
Userhar en anpassad manager som har följande hjälpmetoder (utöver de metoder som tillhandahålls avBaseUserManager):- create_user(username, email=None, password=None, **extra_fields)¶
- acreate_user(username, email=None, password=None, **extra_fields)¶
Asynkron version:
acreate_user()Skapar, sparar och returnerar en
User.usernameochpasswordär inställda som angivet. Domändelen avemailkonverteras automatiskt till gemener, och det returneradeUser-objektet kommer att hais_activesatt tillTrue.Om inget lösenord anges kommer
set_unusable_password()att anropas.Om ingen e-postadress anges kommer
emailatt sättas till en tom sträng.Nyckelordsargumenten
extra_fieldsskickas tillUser’s__init__metod för att tillåta inställning av godtyckliga fält på en custom user model.Se Skapa användare för exempel på användning.
Changed in Django 5.2:metoden
acreate_user()har lagts till.
- create_superuser(username, email=None, password=None, **extra_fields)¶
- acreate_superuser(username, email=None, password=None, **extra_fields)¶
Asynkron version:
acreate_superuser()Samma som
create_user(), men sätteris_staffochis_superusertillTrue.Changed in Django 5.2:metoden
acreate_superuser()har lagts till.
- with_perm(perm, is_active=True, include_superusers=True, backend=None, obj=None)¶
Returnerar användare som har den givna behörigheten
permantingen i formatet"<app label>.<permission codename>"eller som enPermission-instans. Returnerar en tom frågeuppsättning om inga användare som harpermhittas.Om
is_activeärTrue(standard) returneras endast aktiva användare, eller omFalsereturneras endast inaktiva användare. AnvändNoneför att returnera alla användare oavsett aktivt tillstånd.Om
include_superusersärTrue(standard) kommer resultatet att inkludera superanvändare.Om
backendskickas in och det är definierat iAUTHENTICATION_BACKENDS, så kommer denna metod att använda det. Annars kommer den att användabackendiAUTHENTICATION_BACKENDS, om det bara finns en, eller skapa ett undantag.
objektet AnonymUser¶
- class models.AnonymousUser¶
django.contrib.auth.models.AnonymousUserär en klass som implementerar gränssnittetdjango.contrib.auth.models.User, med dessa skillnader:id är alltid
None.usernameär alltid en tom sträng.get_username()returnerar alltid den tomma strängen.is_anonymousärTrueistället förFalse.is_authenticatedärFalseistället förTrue.is_staffochis_superuserär alltidFalse.is_activeär alltidFalse.groupsochuser_permissionsär alltid tomma.set_password(),check_password(),save()ochdelete()ger upphov tillNotImplementedError.
I praktiken kommer du förmodligen inte att behöva använda AnonymousUser-objekt på egen hand, men de används av webbförfrågningar, vilket förklaras i nästa avsnitt.
Bemyndigande modell¶
- class models.Permission¶
Fält¶
Permission-objekt har följande fält:
- class models.Permission
- name¶
Obligatoriskt. 255 tecken eller färre. Exempel:
'Kan rösta'.
- content_type¶
Krävs. En främmande nyckel till modellen
ContentType.
- codename¶
Krävs. 100 tecken eller färre. Exempel:
'can_vote'.
Metoder¶
Permission-objekt har standardmetoder för dataåtkomst som alla andra Django-modeller.
Grupp modell¶
- class models.Group¶
Fält¶
Group-objekt har följande fält:
- class models.Group
- name¶
Krävs. 150 tecken eller färre. Alla tecken är tillåtna. Exempel:
'Fantastiska användare'.
- permissions¶
Många-till-många-fält till
Permission:group.permissions.set([permission_list]) group.permissions.add(permission, permission, ...) group.permissions.remove(permission, permission, ...) group.permissions.clear()
Validerare¶
- class validators.ASCIIUsernameValidator¶
En fältvalidator som endast tillåter ASCII-bokstäver och siffror, förutom
@,.,+,-och_.
- class validators.UnicodeUsernameValidator¶
En fältvalidator som tillåter Unicode-tecken, utöver
@,.,+,-och_. Standardvalideraren förUser.username.
Signaler för inloggning och utloggning¶
Auth-ramverket använder följande signals som kan användas för att meddela när en användare loggar in eller ut.
- user_logged_in¶
Skickas när en användare loggar in framgångsrikt.
Argument som skickas med denna signal:
- avsändare
Klassen för den användare som just loggade in.
begäranDen aktuella
HttpRequest-instansen.användareDen användarinstans som just loggade in.
- user_logged_out¶
Skickas när utloggningsmetoden anropas.
- avsändare
Som ovan: klassen för den användare som just loggade ut eller
Noneom användaren inte var autentiserad.begäranDen aktuella
HttpRequest-instansen.användareDen användarinstans som just loggade ut eller
Noneom användaren inte var autentiserad.
- user_login_failed¶
Skickas när användaren misslyckats med att logga in
- avsändare
Namnet på den modul som används för autentisering.
referenserEn ordbok med nyckelordsargument som innehåller de användaruppgifter som skickades till
authenticate()eller din egen anpassade autentiseringsbackend. Autentiseringsuppgifter som matchar en uppsättning ”känsliga” mönster (inklusive lösenord) kommer inte att skickas i klartext som en del av signalen.begäranObjektet
HttpRequest, om ett sådant tillhandahölls tillauthenticate().
Backend för autentisering¶
Detta avsnitt beskriver de autentiseringsbackends som levereras med Django. För information om hur du använder dem och hur du skriver dina egna autentiseringsbackends, se Andra autentiseringskällor avsnitt i User authentication guide.
Tillgängliga backends för autentisering¶
Följande backends finns tillgängliga i django.contrib.auth.backends:
- class BaseBackend[source]¶
En basklass som tillhandahåller standardimplementationer för alla nödvändiga metoder. Som standard kommer den att avvisa alla användare och inte ge några behörigheter.
- aget_user_permissions(user_obj, obj=None)¶
Asynkron version:
aget_user_permissions()Returnerar en tom uppsättning.
Changed in Django 5.2:funktionen
aget_user_permissions()har lagts till.
- aget_group_permissions(user_obj, obj=None)¶
Asynkron version:
aget_group_permissions()Returnerar en tom uppsättning.
Changed in Django 5.2:funktionen
aget_group_permissions()har lagts till.
- aget_all_permissions(user_obj, obj=None)¶
Asynkron version:
aget_all_permissions()Använder
get_user_permissions()ochget_group_permissions()för att hämta den uppsättning behörighetssträngar somuser_objhar.Changed in Django 5.2:funktionen
aget_all_permissions()har lagts till.
- ahas_perm(user_obj, perm, obj=None)¶
Asynkron version:
ahas_perm()Använder
get_all_permissions()för att kontrollera omuser_objhar behörighetssträngenperm.Changed in Django 5.2:funktionen
ahas_perm()har lagts till.
- class ModelBackend[source]¶
Detta är den standardautentiseringsbackend som används av Django. Den autentiserar med hjälp av referenser som består av en användaridentifierare och ett lösenord. För Djangos standardanvändarmodell är användaridentifieraren användarnamnet, för anpassade användarmodeller är det fältet som anges av USERNAME_FIELD (se Anpassa användare och autentisering).
Den hanterar också standardbehörighetsmodellen enligt definitionen för
UserochPermissionsMixin.has_perm(),get_all_permissions(),get_user_permissions(), ochget_group_permissions()tillåter att ett objekt skickas som en parameter för objektspecifika behörigheter, men denna backend implementerar dem inte annat än att returnera en tom uppsättning behörigheter omobj är inte None.with_perm()tillåter också att ett objekt skickas som en parameter, men till skillnad från andra metoder returnerar den en tom frågeuppsättning omobj är inte None.- aauthenticate(request, username=None, password=None, **kwargs)¶
Asynkron version:
aauthenticate()Försöker autentisera
usernamemedpasswordgenom att anropaUser.check_password. Om ingetusernameanges försöker den hämta ett användarnamn frånkwargsmed hjälp av nyckelnCustomUser.USERNAME_FIELD. Returnerar en autentiserad användare ellerNone.requestär enHttpRequestoch kan varaNoneom den inte tillhandahölls tillauthenticate()(som skickar den vidare till backend).Changed in Django 5.2:funktionen
aauthenticate()har lagts till.
- aget_user_permissions(user_obj, obj=None)¶
Asynkron version:
aget_user_permissions()Returnerar den uppsättning behörighetssträngar som
user_objhar från sina egna användarbehörigheter. Returnerar en tom uppsättning omis_anonymouselleris_activeärFalse.Changed in Django 5.2:funktionen
aget_user_permissions()har lagts till.
- aget_group_permissions(user_obj, obj=None)¶
Asynkron version:
aget_group_permissions()Returnerar den uppsättning behörighetssträngar som
user_objhar från behörigheterna för de grupper de tillhör. Returnerar en tom uppsättning omis_anonymouselleris_activeärFalse.Changed in Django 5.2:funktionen
aget_group_permissions()har lagts till.
- aget_all_permissions(user_obj, obj=None)¶
Asynkron version:
aget_all_permissions()Returnerar den uppsättning behörighetssträngar som
user_objhar, inklusive både användar- och gruppbehörigheter. Returnerar en tom uppsättning omis_anonymouselleris_activeärFalse.Changed in Django 5.2:funktionen
aget_all_permissions()har lagts till.
- ahas_perm(user_obj, perm, obj=None)¶
Asynkron version:
ahas_perm()Använder
get_all_permissions()för att kontrollera omuser_objhar behörighetssträngenperm. ReturnerarFalseom användaren inte äris_active.Changed in Django 5.2:funktionen
ahas_perm()har lagts till.
- ahas_module_perms(user_obj, app_label)¶
Asynkron version:
ahas_module_perms()Returnerar om
user_objhar några behörigheter för appenapp_label.Changed in Django 5.2:funktionen
ahas_module_perms()har lagts till.
- user_can_authenticate()[source]¶
Returnerar om användaren tillåts att autentisera sig. För att matcha beteendet hos
AuthenticationFormsomförbjuder inaktiva användare från att logga in, returnerar denna metodFalseför användare medis_active=False. Anpassade användarmodeller som inte har ett fältis_activeär tillåtna.
- with_perm(perm, is_active=True, include_superusers=True, obj=None)[source]¶
Returnerar alla aktiva användare som har behörigheten
permantingen i form av"<app label>.<permission codename>"eller enPermission-instans. Returnerar en tom frågeuppsättning om inga användare som harpermhittas.Om
is_activeärTrue(standard) returneras endast aktiva användare, eller omFalsereturneras endast inaktiva användare. AnvändNoneför att returnera alla användare oavsett aktivt tillstånd.Om
include_superusersärTrue(standard) kommer resultatet att inkludera superanvändare.
- class AllowAllUsersModelBackend[source]¶
Samma som
ModelBackendförutom att den inte avvisar inaktiva användare eftersomuser_can_authenticate()alltid returnerarTrue.När du använder den här backend kommer du sannolikt att vilja anpassa
AuthenticationFormsom används avLoginViewgenom att åsidosättaconfirm_login_allowed()-metoden eftersom den avvisar inaktiva användare.
- class RemoteUserBackend[source]¶
Använd denna backend för att dra nytta av autentisering som hanteras externt till Django. Den autentiserar med användarnamn som skickas i
request.META['REMOTE_USER']. Se dokumentationen Autenticering mot REMOTE_USER.Om du behöver mer kontroll kan du skapa din egen autentiseringsbackend som ärver från den här klassen och åsidosätta dessa attribut eller metoder:
- create_unknown_user¶
TrueellerFalse. Bestämmer om ett användarobjekt skapas eller inte om det inte redan finns i databasen Standardvärdet ärTrue.
- aauthenticate(request, remote_user)¶
Asynkron version:
aauthenticate()Det användarnamn som anges som
remote_useranses vara betrott. Denna metod returnerar användarobjektet med det angivna användarnamnet och skapar ett nytt användarobjekt omcreate_unknown_userärTrue.Returnerar
Noneomcreate_unknown_user`ärFalseoch ettUser-objekt med det angivna användarnamnet inte finns i databasen.requestär enHttpRequestoch kan varaNoneom den inte tillhandahölls tillauthenticate()(som skickar den vidare till backend).Changed in Django 5.2:funktionen
aauthenticate()har lagts till.
- clean_username(username)[source]¶
Utför eventuell rensning av
username(t.ex. borttagning av LDAP DN-information) innan det används för att hämta eller skapa ett användarobjekt. Returnerar det rensade användarnamnet.
- aconfigure_user(request, user, created=True)¶
Asynkron version:
aconfigure_user()Konfigurerar användaren vid varje autentiseringsförsök. Den här metoden anropas omedelbart efter att användaren som autentiseras har hämtats eller skapats och kan användas för att utföra anpassade konfigurationsåtgärder, t.ex. att ange användarens grupper baserat på attribut i en LDAP-katalog. Returnerar användarobjektet. När hämtning eller skapande av en användare anropas från en synkron kontext anropas
configure_user,aconfigure_useranropas från asynkrona kontexter.Inställningen kan utföras antingen en gång när användaren skapas (
createdärTrue) eller på befintliga användare (createdärFalse) som ett sätt att synkronisera attribut mellan fjärrsystemet och det lokala systemet.requestär enHttpRequestoch kan varaNoneom den inte tillhandahölls tillauthenticate()(som skickar den vidare till backend).Changed in Django 5.2:funktionen
aconfigure_user()har lagts till.
- user_can_authenticate()¶
Returnerar om användaren får autentisera sig. Denna metod returnerar
Falseför användare medis_active=False. Anpassade användarmodeller som inte har ett fältis_activeär tillåtna.
- class AllowAllUsersRemoteUserBackend[source]¶
Samma som
RemoteUserBackendförutom att den inte avvisar inaktiva användare eftersomuser_can_authenticatealltid returnerarTrue.
Verktygsfunktioner¶
- aget_user(request)¶
Asynkron version:
aget_user()Returnerar den användarmodellinstans som är associerad med den givna
request-sessionen.Den kontrollerar om den autentiseringsbackend som lagrats i sessionen finns i
AUTHENTICATION_BACKENDS. Om så är fallet använder den backendets metodget_user()för att hämta användarmodellens instans och verifierar sedan sessionen genom att anropa användarmodellens metodget_session_auth_hash(). Om verifieringen misslyckas ochSECRET_KEY_FALLBACKStillhandahålls, verifieras sessionen mot varje reservnyckel medget_session_auth_fallback_hash().Returnerar en instans av
AnonymousUserom den autentiseringsbackend som lagras i sessionen inte längre finns iAUTHENTICATION_BACKENDS, om en användare inte returneras av backendetsget_user()-metod, eller om sessionens autentiseringshash inte valideras.