Menggunakan sistem pembuktian keaslian Django¶
Dokumen ini menjelaskan penggunaan dari sistem otentifikasi Django di konfigurasi awalannya. Konfigurasi ini telah berkembang untuk melayani kebutuhan proyek paling umum, menangani jangkauan luas beralasan dari tugas, dan mempunyai penerapan cermat dari sandi dan perizinan. Untuk proyek dimana otentifikasi butuh berbeda dari awalan, Django mendukung extension and customization luas dari otentifikasi.
Otentifikasi Django menyediakan kedua otentifikasi dan otorisasi bersama-sama dan umumnya mengacu pada sebagai sistem otentifikasi, ketika fitur ini agak digabungkan.
Obyek User¶
Obyek User adalah inti dari sistem autentifikasi. Mereka khususnya mewakili orang berinteraksi dengan situs anda dan digunakan untuk mengadakan hal-hal seperti membatasi akses, mendaftarkan profil pengguna, menyatukan isi dengan pembuat dll. Hanya satu kelas dari pengguna yang ada di otentifikasi kerangka kerja Django, yaitu, 'superusers' atau admin pengguna 'staff' hanya obyek user dengan sekumpulan atribut khusus, bukan kelas-kelas berbeda dari obyek user.
Atribut utama dari pengguna awal adalah:
Lihat :class:`full API documentation <django.contrib.auth.models.User>`untuk acuan penuh, dokumentasi yang mengikuti lebih berorientasi tugas.
Membuat pengguna¶
Cara paling langsung untuk membuat pengguna adalah dengan menggunakan fungsi pembantu create_user() yang disertakan:
>>> from django.contrib.auth.models import User
>>> user = User.objects.create_user("john", "lennon@thebeatles.com", "johnpassword")
# At this point, user is a User object that has already been saved
# to the database. You can continue to change its attributes
# if you want to change other fields.
>>> user.last_name = "Lennon"
>>> user.save()
Jika anda mempunai admin Django dipasang, anda dapat juga create users interactively.
Membuat pengguna hebat¶
Buat pengguna super menggunakan perintah createsuperuser:
$ python manage.py createsuperuser --username=joe --email=joe@example.com
...\> py manage.py createsuperuser --username=joe --email=joe@example.com
Anda akan diminta untuk sandi. Setelah anda memasukkan satu, pengguna akan membuat dengan segera. Jika anda membiarkan mati pilihan --username atau --email, itu akan meminta anda untuk nilai-nilai tersebut.
Merubah sandi¶
Django tidak menyimpan sandi (teks bersih) mentah pada model user, tetapi hanya campuran (lihat documentation of how passwords are managed untuk rincian penuh). Karena dari ini, jangan mencoba untuk mengubah atribut sanddi dari pengguna secara langsung. Ini adalah mengapa fungsi pembantu digunakan ketika membuat pengguna.
Untuk merubah sandi pengguna, anda mempunyai beebrapa pilihan:
manage.py changepassword *username* menawarkan metode dari merubah sandi pengguna dari baris perintah. Itu mendorong anda merubah sandi dari pengguna yang diberikan yang anda harus masukkan dua kali. Jika mereka kedua cocok, sandi baru akan berubah segera. Jika anda tidak memasok pengguna, perintah akan berusaha merubah sandi yang nama pengguna cocok dengan pengguna sistem saat ini.
You can also change a password programmatically, using
set_password():
>>> from django.contrib.auth.models import User
>>> u = User.objects.get(username="john")
>>> u.set_password("new password")
>>> u.save()
Jika anda mempunyai admin Django terpasang, anda dapat juga merubah sandi pengguna pada halaman admin sistem pembuktian keaslian.
Django juga menyediakan views dan forms yang mungkin digunakan untuk mengizinkan pengguna merubah sandi mereka sendiri.
Merubah sandi pengguna akan keluar semua sesi mereka. Lihat Penghapusan sesi pada perubahan sandi untuk rincian.
Pembuktian keaslian pengguna¶
- aauthenticate(request=None, **credentials)¶
Versi asinkron:
aauthenticate()Use
authenticate()to verify a set of credentials. It takes credentials as keyword arguments,usernameandpasswordfor the default case, checks them against each authentication backend, and returns aUserobject if the credentials are valid for a backend. If the credentials aren't valid for any backend or if a backend raisesPermissionDenied, it returnsNone. For example:from django.contrib.auth import authenticate user = authenticate(username="john", password="secret") if user is not None: # A backend authenticated the credentials ... else: # No backend authenticated the credentials ...
requestadalah sebuah pilihanHttpRequestyang dilewatkan pada metodeauthenticate()dari backend autentifikasi.Catatan
Ini adalah cara tingkat bawah untuk mengautentifikasi kumpulan dari kepercayaan; sebagai contoh, itu digunakan oleh
RemoteUserMiddleware. Meskipun anda sedang menulis sisten autentifikasi anda sendiri, anda mungkin tidak menggunakan ini. Daripada jika anda sedang mencari cara untuk masuk seorang pengguna, gunakanLoginView.
Otentikasi dalam permintaan web¶
Django menggunakan sessions dan middleware untuk menghubungkan sitem otentifikasi kedalam request objects.
Ini menyediakan atribut metode asinkron request.user dan request.auser pada setiap permintaan yang mewakili pengguna saat ini. Jika pengguna saat ini tidak masuk, atribut ini akan mensetel instance dari AnonymousUser, sebaliknya itu akan menjadi instance User.
Anda dapat memberitahu mereka selain dengan is_authenticated, seperti begitu
if request.user.is_authenticated:
# Do something for authenticated users.
...
else:
# Do something for anonymous users.
...
Atau dalam tampilan asinkron:
user = await request.auser()
if user.is_authenticated:
# Do something for authenticated users.
...
else:
# Do something for anonymous users.
...
Bagaimana cara masuk pengguna¶
Jika anda mempunyai pengguna terotentifikasi anda ingin lampirkan ke sesi saat ini - ini dilakukan dengan fungsi login().
- alogin(request, user, backend=None)¶
Versi asinkron:
alogin()To log a user in, from a view, use
login(). It takes anHttpRequestobject and aUserobject.login()saves the user's ID in the session, using Django's session framework.Catat bahwa tiap data disetel selama sesi anonim dipertahankan di sesi setelah pengguna masuk.
This example shows how you might use both
authenticate()andlogin():from django.contrib.auth import authenticate, login def my_view(request): username = request.POST["username"] password = request.POST["password"] user = authenticate(request, username=username, password=password) if user is not None: login(request, user) # Redirect to a success page. ... else: # Return an 'invalid login' error message. ...
Memilih backend otentifikasi¶
Ketika seorang pengguna masuk, ID pengguna dan backend yang telah digunakan untuk autentifikasi disimpan dalam sesi pengguna. Ini mengizinkan authentication backend sama untuk mengambil rincian pengguna pada permintaan akan datang. Backend autentifikasi untuk menyimpan sesi dipilih sebagai berikut:
Gunakan nilai dai argumen
backendpilihan, jika disediakan.Use the value of the
user.backendattribute, if present. This allows pairingauthenticate()andlogin():authenticate()sets theuser.backendattribute on the user object it returns.Gunakan
backenddalamAUTHENTICATION_BACKENDS, jika hanya ada satu.Sebaliknya, munculkan sebuah pengecualian.
Di kasus 1 dan 2, nilai dari argumen backend atau atribut user.backend harus di impor bertitik jalur deretan karakter (seperti yang ditemukan di AUTHENTICATION_BACKENDS), bukan kelas backend sebenarnya.
Bagaimana cara pengguna keluar¶
- alogout(request)¶
Versi asinkron:
alogout()To log out a user who has been logged in via
django.contrib.auth.login(), usedjango.contrib.auth.logout()within your view. It takes anHttpRequestobject and has no return value. Example:from django.contrib.auth import logout def logout_view(request): logout(request) # Redirect to a success page.
Note that
logout()doesn't throw any errors if the user wasn't logged in.When you call
logout(), the session data for the current request is completely cleaned out. All existing data is removed. This is to prevent another person from using the same web browser to log in and have access to the previous user's session data. If you want to put anything into the session that will be available to the user immediately after logging out, do that after callingdjango.contrib.auth.logout().
Membatasi akses ke pengguna masuk¶
Cara mentah¶
Cara mentah untuk membatasi akses ke halaman adalah dengan memeriksa request.user.is_authenticated dan mengarahkan ulang ke halaman login:
from django.conf import settings
from django.shortcuts import redirect
def my_view(request):
if not request.user.is_authenticated:
return redirect(f"{settings.LOGIN_URL}?next={request.path}")
# ...
...atau menampilkan pesan kesalahan:
from django.shortcuts import render
def my_view(request):
if not request.user.is_authenticated:
return render(request, "myapp/login_error.html")
# ...
Penghias login_required¶
- login_required(redirect_field_name='next', login_url=None)[sumber]¶
Sebagai jalan pintas, anda dapat menggunakan penghias
login_required()yang cocok.from django.contrib.auth.decorators import login_required @login_required def my_view(request): ...
login_required()melakukan berikut:Jika pengguna tidak masuk, alihkan ke
settings.LOGIN_URL, melewati jalur mutlak saat ini di permintaan deretan karakter. Contoh:/accounts/login/?next=/polls/3/.Jika pengguna masuk, jalankan tampilan secara biasa. Kode tampilan adalah bebas untuk menganggap pengguna adalah masuk.
Secara awalan, jalur yang pengguna harus dialihkan untuk atas keberhasilan otentifikasi adalah disimpan di permintaan parameter deretan karakter disebut
"next". Jika anda akan memilih menggunakan nama berbeda untuk parameter ini,login_required()mengambil sebuah pilihan parameterredirect_field_name.from django.contrib.auth.decorators import login_required @login_required(redirect_field_name="my_redirect_field") def my_view(request): ...
Catat bahwa jika anda menyediakan nilai pada
redirect_field_name, anda akan paling disukai butuh menyesuaikan cetakan masuk anda juga, sejak cetakan varaibel konteks yang menyimpan jalur pengalihan akan menggunakan nilai dariredirect_field_name``sebagai kuncinya daripada ``"next"(awalan).login_required()juga mengambil sebuah pilihan parameterlogin_url. Contoh:from django.contrib.auth.decorators import login_required @login_required(login_url="/accounts/login/") def my_view(request): ...
Catat bahwa jika anda tidak menentukan parameter
login_url, anda akan butuh memastikan bahwasettings.LOGIN_URLdan tampilan masuk anda benar terhubung. Sebagai contoh, menggunakan awalan, tambah baris berikut ke URLconf anda:from django.contrib.auth import views as auth_views path("accounts/login/", auth_views.LoginView.as_view()),
settings.LOGIN_URLjuga menerima nama-nama fungsi tampilan dan named URL patterns. Ini mengizinkan anda secara bebas memetakan kembali ke tampilan masuk anda dalam URLconf tanpa harus memperbaharui pengaturan.
Catatan
Penghias login_required TIDAK memeriksa bendera is_active pada pengguna, tetapi awalan AUTHENTICATION_BACKENDS menolak pengguna tidak aktif.
Lihat juga
Jika anda sedang menulis tampilan penyesuaian untuk Django admin (atau butuh pemeriksaan otorisasi sama bahwa tampilan pasang-tetap digunakan), anda mungkin menemukan penghias django.contrib.admin.views.decorators.staff_member_required() cara lain yang berguna pada login_required().
Mixin LoginRequiredMixin¶
Ketika menggunakan class-based views, anda dapat mencapai kebiasaan lama seperti dengan login_required dengan menggunakan LoginRequiredMixin. Mixin harus di tempat paling kanan di daftar warisan.
- class LoginRequiredMixin[sumber]¶
Jika sebuah tampilan menggunakan mixin ini, semua permintaan oleh pengguna bukan-terotentifikasi akan dialihkan ke halaman masuk atau menampilkan kesalahan HTTP 403 Forbidden, tergantung pada parameter
raise_exception.Anda dapat menyetel tiap dari parameter dari
AccessMixinuntuk menyesuaikan menangani dari pengguna tidak sah:from django.contrib.auth.mixins import LoginRequiredMixin class MyView(LoginRequiredMixin, View): login_url = "/login/" redirect_field_name = "redirect_to"
Catatan
Seperti penghias login_required mixin ini TIDAK memeriksa bendera is_active pada pengguna, tetapi awalan AUTHENTICATION_BACKENDS menolak pengguna tidak aktif.
Decorator login_not_required¶
When LoginRequiredMiddleware is
installed, all views require authentication by default. Some views, such as the
login view, may need to disable this behavior.
- login_not_required()[sumber]¶
Allows unauthenticated requests to this view when
LoginRequiredMiddlewareis installed.
Membatasi akses ke pengguna masuk yang melewatkan percobaan¶
Untuk membatasi akses berdasarkan pada perizinan tertentu atau beberapa percobaan lain, anda akan melakukan pada dasarnya hal sama seperti digambarkan di bagian sebelumnya.
Anda dapat menjalankan pengujian anda pada request.user di tampilan secara langsung. Misalnya, tampilan ini memeriksa untuk memastikan pengguna memiliki surel di domain yang diinginkan dan jika tidak, dialihkan ke halaman login
from django.shortcuts import redirect
def my_view(request):
if not request.user.email.endswith("@example.com"):
return redirect("/login/?next=%s" % request.path)
# ...
- user_passes_test(test_func, login_url=None, redirect_field_name='next')[sumber]¶
Sebagai sebuah jalan pintas, anda dapat menggunakan penghias
user_passes_testyang cocok yang melakukan sebuah pengalihan ketika callable mengembalikanFalse:from django.contrib.auth.decorators import user_passes_test def email_check(user): return user.email.endswith("@example.com") @user_passes_test(email_check) def my_view(request): ...
user_passes_test()mengambil argumen wajib: sebuah callable yang mengambil obyekUserdan mengembalikanTruejika pengguna diizinkan melihat halaman. Catat bahwauser_passes_test()tidak secara otomatis memeriksa bahwa theUserbukan anonim.user_passes_test()mengambil dua argumen pilihan:login_urlBiarkan anda menentukan URL yang pengguna tidak melewati percobaan akan dialihkan. Itu mungkin halaman masuk dan awalan ke
settings.LOGIN_URLjika anda tidak menentukan satu.redirect_field_nameSama seperti
login_required(). Atur itu keNonememindahkannya dari URL, yang anda mungkin ingin melakukannya jika anda mengalihkan pengguna yang tidak melewati percobaan ke halaman bukan-masuk dimana tidak ada "next page".
Sebagai contoh:
@user_passes_test(email_check, login_url="/login/") def my_view(request): ...
- class UserPassesTestMixin[sumber]¶
Ketika menggunakan class-based views, anda dapat menggunakan
UserPassesTestMixinuntuk melakukan ini.- test_func()[sumber]¶
Anda harus menimpa metode
test_func()dari kelas untuk menyediakan percobaan yang dilakukan. Lebih lanjut, anda dapat menyetel tiap parameter dariAccessMixinuntuk menyesuaikan penangangan dari pengguna tidak sah:from django.contrib.auth.mixins import UserPassesTestMixin class MyView(UserPassesTestMixin, View): def test_func(self): return self.request.user.email.endswith("@example.com")
- get_test_func()[sumber]¶
Anda dapat juga menimpa metode
get_test_func()untuk memiliki penggunaan mixin fungsi bernama berbeda untuk pemeriksaannya (sebagai gantitest_func()).
Menumpuk
UserPassesTestMixinDiakrenakan cara
UserPassesTestMixinditerapkan, anda tida dapat menumpuk mereka di daftar warisan anda. Berikut TIDAK bekerja:class TestMixin1(UserPassesTestMixin): def test_func(self): return self.request.user.email.endswith("@example.com") class TestMixin2(UserPassesTestMixin): def test_func(self): return self.request.user.username.startswith("django") class MyView(TestMixin1, TestMixin2, View): ...
Jika
TestMixin1akan memanggilsuper()dan mengambil hasi itu kedalam akun,TestMixin1tidak akan bekerja berdiri sendiri lagi.
Penghias permission_required¶
- permission_required(perm, login_url=None, raise_exception=False)[sumber]¶
It's a relatively common task to check whether a user has a particular permission. For that reason, Django provides a shortcut for that case: the
permission_required()decorator:from django.contrib.auth.decorators import permission_required @permission_required("polls.add_choice") def my_view(request): ...
Sama seperti metode
has_perm(), nama izin mengambil bentuk"<app label>.<permission codename>"(yaitupolls.add_choiceuntuk izin pada model di aplikasipolls).Penghias mungkin juga mengambil perizinan berulang, dalam hal ini pengguna harus memiliki semua perizinan untuk mengakses tampilan.
Note that
permission_required()also takes an optionallogin_urlparameter:from django.contrib.auth.decorators import permission_required @permission_required("polls.add_choice", login_url="/loginpage/") def my_view(request): ...
Ketika di penghias
login_required(), awalanlogin_urlkesettings.LOGIN_URL.Jika parameter
raise_exceptiondiberikan, penghias akan memunculkanPermissionDenied, mendorong the 403 (HTTP Forbidden) view daripada mengalihkan ke halaman masuk.Jika anda ingin menggunakan
raise_exceptiontetapi juga memberikan pengguna anda kesempatan untuk masuk terlebih dahulu, anda dapat menambahkan penghiaslogin_required():from django.contrib.auth.decorators import login_required, permission_required @login_required @permission_required("polls.add_choice", raise_exception=True) def my_view(request): ...
Ini juga menghindari peralihan pengulangan ketika
LoginViewredirect_authenticated_user=Truedan pengguna yang masuk tidak memiliki semua izin yang diperlukan.
Mixin PermissionRequiredMixin¶
Untuk memberlakukan pemeriksaan perizinan pada class-based views, anda dapat menggunakan PermissionRequiredMixin:
- class PermissionRequiredMixin[sumber]¶
Mixin ini, seperti penghias
permission_required, memeriksa apakah pengguna mengakses sebuah tampilan mempunyai semua perizinan yang diberikan. Anda harus menentukan perizinan (atau perulangan dari perizinan) menggunakan parameterpermission_required:from django.contrib.auth.mixins import PermissionRequiredMixin class MyView(PermissionRequiredMixin, View): permission_required = "polls.add_choice" # Or multiple of permissions: permission_required = ["polls.view_choice", "polls.change_choice"]
Anda dapat menyetel tiap dari parameter dari
AccessMixinuntuk menyesuaikan menangani dari pengguna tidak sah.Anda dapat juga menimpa metode ini:
- get_permission_required()[sumber]¶
Mengembalikan perulangan dari nama perizinan digunakan oleh mixin. Awalan pada atribut
permission_required, dirubah ke sebuah tuple juka memungkinkan.
- has_permission()[sumber]¶
Returns a boolean denoting whether the current user has permission to execute the decorated view. By default, this returns the result of calling
has_perms()with the list of permissions returned byget_permission_required().
Tampilan Otentifikasi¶
Django menyediakan beberapa tampilan yang anda dapat gunakan untuk menangani masuk, keluarm dan pengelolaan sandi. Ini menggunakan dari stock auth forms tetapi anda dapat melewatkan nya ke dalam formulir anda sendiri juga.
Django menyediakan tidak ada awalan cetakan untuk tampilan otentifikasi. Anda harus membuat cetakan anda sendiri untuk tampilan anda ingin gunakan. Konteks cetakan adalah terdokumentasi di setiap tampilan, lihat Semua tempilan otentifikasi.
Menggunakan tamplian¶
Ada perbedaan metode untuk menerapkan tampilan ini di proyek anda. Cara termudah adalah menyertakan URLconf yang disediakan di django.contrib.auth.urls dalam URLConf anda sendiri, sebagai contoh:
urlpatterns = [
path("accounts/", include("django.contrib.auth.urls")),
]
Ini akan mencakup pola URL berikut:
accounts/login/ [name='login']
accounts/logout/ [name='logout']
accounts/password_change/ [name='password_change']
accounts/password_change/done/ [name='password_change_done']
accounts/password_reset/ [name='password_reset']
accounts/password_reset/done/ [name='password_reset_done']
accounts/reset/<uidb64>/<token>/ [name='password_reset_confirm']
accounts/reset/done/ [name='password_reset_complete']
Tampilan menyediakan nama URL untuk acuan lebih mudah. Lihat the URL documentation untuk rincian pada menggunakan corak URL bernama.
Jika anda ingin kendali lebih terhadap URL anda, anda dapat mengacu tampilan khusus di URLconf:
from django.contrib.auth import views as auth_views
urlpatterns = [
path("change-password/", auth_views.PasswordChangeView.as_view()),
]
Tampilan mempunyai argumen pilihan anda dapat gunakan untuk merubah kebiasaan dari tampilan. Sebagai contoh, jika anda ingin merubah nama cetakan tampilan kegunaan, anda dapat menyediakan argumen template_name. Sebuah cara untuk melakukan ini adalah menyediakan argumen kata kunci dalam URLconf, ini akan dilewatkan ke tampilan. Sebagai contoh:
urlpatterns = [
path(
"change-password/",
auth_views.PasswordChangeView.as_view(template_name="change-password.html"),
),
]
Semua tampilan adalah class-based, yang mengizinkan anda dengan mudah menyesuaikan mereka dengan mensubkelaskan.
Semua tempilan otentifikasi¶
Ini adalah daftar dengan semua tamilan django.contrib.auth sediakan. Untuk penerapan rincian lihat Menggunakan tamplian.
- class LoginView[sumber]¶
Nama URL:
masukLihat the URL documentation untuk rincian pada menggunakan corak URL bernama.
Cara dan Atribut
- template_name¶
Nama cetakan yang akan ditampilkan untuk tampilan yang digunakan untuk login pengguna. Awalannya adalah
registration/login.html.
- next_page¶
URL tujuan pengalihan setelah login. Awalan ke
LOGIN_REDIRECT_URL.
- redirect_field_name¶
Nama bidang
GETberisi URL tujuan pengalihan setelah login. Awalan keberikutnya. Mengganti URLget_default_redirect_url()jika parameterGETyang diberikan diteruskan.
- authentication_form¶
Callable (biasanya kelas formulir) yang digunakan untuk autentikasi. Bawaan ke
AuthenticationForm.
- extra_context¶
Kamus data kontek yang akan ditambahkan ke data kontek awalan yang diteruskan ke cetakan.
- redirect_authenticated_user¶
Boolean yang mengontrol apakah pengguna terotentikasi mengakses halaman login atau tidak akan dialihkan seolah-olah mereka baru saja berhasil login. Awalan ke
False.Peringatan
Jika anda mengadakan
redirect_authenticated_user, jaringan situs lainnya akan dapat menentukan jika pengunjung mereka adalah terotentifikasi pada situs anda dengan meminta pengalihan URL ke berkas gambar pada situs jaringan anda. Untuk menghindari ini "social media fingerprinting" kebocoran informasi, simpan semua gambar dan favicon anda pada ranah terpisah.Mengaktifkan
redirect_authenticated_userjuga dapat mengakibatkan pengalihan perulangan saat menggunakan dekoratorpermission_required()kecuali parameterraise_exceptiondigunakan.
- success_url_allowed_hosts¶
Sebuah
setdari host, selainrequest.get_host(), yang aman untuk dialihkan setelah login. Awalan kesetkosong.
- get_default_redirect_url()[sumber]¶
Mengembalikan URL tujuan pengalihan setelah masuk. Penerapan awalan menyelesaikan dan mengembalikan
next_pagejika disetel, atau sebaliknyaLOGIN_REDIRECT_URL.
Ini adalah apa
LoginViewlakukan:Jika dipanggil melalui
GET, itu menampilkan formulir masuk yang POST ke URL sama.Lebih dari ini dalam bit.Jika dipanggil melalui
POSTdengan pengguna mengajukan surat kepercayaan, itu mencoba untuk masuk pengguna. Jika masuk berhasil, tampilan mengalihkan ke URL ditentukan dinexttidak menyediakan, itu mengalihkan kesettings.LOGIN_REDIRECT_URL(yang awalan menjadi/accounts/profile/). Jika masuk tidak berhasil, itu menampilkan kembali formulir masuk.
Itu adalah tanggung jawab anda untuk menyediakan html untuk cetakan masuk, dipanggil
registration/login.htmlsecara awalan. Cetakan ini dilewatkan empat cetakan variabel konteks:form: Sebuah obyekFormmewakiliAuthenticationForm.next: URL untuk dialihkan setelah berhasil masuk. Ini mungkin mengandung permintaan string, juga.site:Site`saat ini, menurut pengaturan :setting:`SITE_ID. Jika anda tidak mempunyai kerangka kerja situs terpasang, ini akan disetel ke sebuah instance dariRequestSite, yang memperoleh nama situs dan ranah dariHttpRequestsaat ini.site_name: Sebuah nama lain untuksite.name. Jika anda tidak mempunyai kerangka kerja situs terpasang, ini akan disetel ke nilai darirequest.META['SERVER_NAME']. Untuk lebih di situs, lihat Kerangka kerja "sites".
Jika anda memilih tidak memanggil cetakan
registration/login.html, anda dapat melewatkan parametertemplate_namemelalui argumen tambahan pada metodeas_viewdalam URLConf anda. Sebagai contoh, baris URLconf ini akan menggunakanmyapp/login.htmlsebagai gantinya.path("accounts/login/", auth_views.LoginView.as_view(template_name="myapp/login.html")),
Anda dapat juga menentukan nama dari bidang
GETyang mengandung URL untuk mengalihkan setelah masuk menggunakanredirect_field_name. Secara awalan, bidang dipanggilnext.Ini adalah sebuah contoh cetakan
registration/login.htmlanda dapat gunakan sebagai titik awalan. Itu menganggap anda memiliki sebuah cetakanbase.htmlyang menentukan sebuah blokcontent.{% extends "base.html" %} {% block content %} {% if form.errors %} <p>Your username and password didn't match. Please try again.</p> {% endif %} {% if next %} {% if user.is_authenticated %} <p>Your account doesn't have access to this page. To proceed, please login with an account that has access.</p> {% else %} <p>Please login to see this page.</p> {% endif %} {% endif %} <form method="post" action="{% url 'login' %}"> {% csrf_token %} <table> <tr> <td>{{ form.username.label_tag }}</td> <td>{{ form.username }}</td> </tr> <tr> <td>{{ form.password.label_tag }}</td> <td>{{ form.password }}</td> </tr> </table> <input type="submit" value="login"> <input type="hidden" name="next" value="{{ next }}"> </form> {# Assumes you set up the password_reset view in your URLconf #} <p><a href="{% url 'password_reset' %}">Lost password?</a></p> {% endblock %}
Jika anda telah menyesuaiakan autentifikasi (lihat Customizing Authentication 1) anda dapat menggunakan formulir autentifikasi penyesuaian dengan mengatur atribut
authentication_form. Formulir ini harus menerima sebuah argumen katakuncirequestdalam metode__init__()nya dan menyediakan metodeget_user()yang mengembalikan obyek pengguna terautentifikasi (metode ini hanya dipanggil setelah keberhasilan formulir pengesahan).
- class LogoutView[sumber]¶
Membuat pengguna keluar dari permintaan
POST.Nama URL:
logoutAtribut
- next_page¶
URL tujuan pengalihan setelah keluar. Awalan ke
LOGOUT_REDIRECT_URL.
- template_name¶
Nama lengkap cetakan yang akan ditampilkan setelah pengguna keluar. Awalannya adalah
registration/logged_out.html.
- redirect_field_name¶
Nama bidang
GETberisi URL tujuan pengalihan setelah keluar. Awalan ke'berikutnya'. Mengganti URLnext_pagejika parameterGETyang diberikan diteruskan.
- extra_context¶
Kamus data kontek yang akan ditambahkan ke data kontek awalan yang diteruskan ke cetakan.
- success_url_allowed_hosts¶
Sebuah
setdari host, selainrequest.get_host(), yang aman untuk dialihkan setelah keluar. Awalan kesetkosong.
Kontek cetakan
title: String "Logged out", lokalisasi.site:Site`saat ini, menurut pengaturan :setting:`SITE_ID. Jika anda tidak mempunyai kerangka kerja situs terpasang, ini akan disetel ke sebuah instance dariRequestSite, yang memperoleh nama situs dan ranah dariHttpRequestsaat ini.site_name: Sebuah nama lain untuksite.name. Jika anda tidak mempunyai kerangka kerja situs terpasang, ini akan disetel ke nilai darirequest.META['SERVER_NAME']. Untuk lebih di situs, lihat Kerangka kerja "sites".
- logout_then_login(request, login_url=None)[sumber]¶
Keluarkan pengguna pada permintaan
POST, lalu alihkan ke halaman login.Nama URL: Tidak ada URL awal disediakan
Argumen pilihan
login_url: URL dari halaman masuk untuk mengalihkan. Awalan menjadisettings.LOGIN_URLjika tidak diberikan.
- class PasswordChangeView[sumber]¶
Nama URL:
password_changeIzinkan pengguna merubah sandi mereka.
Atribut
- template_name¶
Nama lengkap cetakan yang akan digunakan untuk menampilkan formulir perubahan kata sandi. Awalan ke
registration/password_change_form.htmljika tidak disediakan.
- success_url¶
URL tujuan pengalihan setelah perubahan sandi berhasil. Awalan ke
'password_change_done'.
- form_class¶
Formulir penyesuaian "ubah kata sandi" yang harus menerima argumen kata kunci
user. Formulir tersebut bertanggung jawab untuk benar-benar mengubah kata sandi pengguna. Awalan kePasswordChangeForm.
- extra_context¶
Kamus data kontek yang akan ditambahkan ke data kontek awalan yang diteruskan ke cetakan.
Kontek cetakan
form: Formulir rubah sandi (lihatform_classdiatas).
- class PasswordChangeDoneView[sumber]¶
Nama URL:
password_change_doneHalaman muncul setelah pengguna telah merubah sandi mereka.
Atribut
- template_name¶
Nama lengkap cetakan yang akan digunakan. Awalan ke
registration/password_change_done.htmljika tidak disediakan.
- extra_context¶
Kamus data kontek yang akan ditambahkan ke data kontek awalan yang diteruskan ke cetakan.
- class PasswordResetView[sumber]¶
Nama URL:
password_resetMengizinkan seorang pengguna menyetel kembali sandi dengan membangkitkan satu-kali penggunaan tautan yang dapat digunakan untuk menyetel kembali sandi, dan mengirim tautan itu ke alamat surel pengguna terdaftar.
Tampilan ini akan mengirim surel jika kondisi berikut terpenuhi:
Alamat surel yang diberikan ada di sistem.
Pengguna yang diminta aktif (
User.is_activeadalahTrue).Pengguna yang diminta memiliki kata sandi yang dapat digunakan. Pengguna ditandai dengan kata sandi yang tidak dapat digunakan (lihat
set_unusable_password()) tidak diizinkan untuk meminta penyetelan ulang kata sandi untuk mencegah penyalahgunaan saat menggunakan sumber autentikasi eksternal seperti LDAP.
Jika salah satu dari ketentuan ini tidak terpenuhi, tidak ada surel yang akan dikirim, tetapi pengguna juga tidak akan menerima pesan kesalahan apa pun. Ini mencegah informasi bocor ke penyerang potensial. Jika anda ingin memberikan pesan kesalahan dalam kasus ini, Anda dapat membuat subkelas
PasswordResetFormdan menggunakan atributform_class.Catatan
Ketahuilah bahwa mengirim surel membutuhkan waktu tambahan, karena itu anda mungkin rentan terhadap serangan waktu pencacahan alamat surel karena perbedaan antara durasi permintaan setel kembali untuk alamat surel yang ada dan durasi permintaan setel kembali untuk alamat surel yang tidak ada . Untuk mengurangi biaya diluar, Anda dapat menggunakan paket pihak ke-3 yang memungkinkan pengiriman surel secara asinkron, mis. django-mailer.
Atribut
- template_name¶
Nama lengkap cetakan yang akan digunakan untuk menampilkan formulir pengaturan ulang kata sandi. Awalan ke
registration/password_reset_form.htmljika tidak disediakan.
- form_class¶
Formulir yang akan digunakan untuk mendapatkan surel pengguna untuk mensetel kembali kata sandi. Awalan ke
PasswordResetForm.
- email_template_name¶
Nama lengkap cetakan yang akan digunakan untuk membuat surel dengan tautan atur ulang kata sandi. Awalan ke
registration/password_reset_email.htmljika tidak disediakan.
- subject_template_name¶
Nama lengkap cetakan yang akan digunakan untuk subjek surel dengan tautan atur ulang kata sandi. Awalan ke
registration/password_reset_subject.txtjika tidak disediakan.
- token_generator¶
Instance dari kelas untuk memeriksa tautan satu kali. Ini akan awalan ke
default_token_generator, ini adalah instance daridjango.contrib.auth.tokens.PasswordResetTokenGenerator.
- success_url¶
URL tujuan pengalihan setelah permintaan setel ulang sandi berhasil. Awalan ke
'password_reset_done'.
- from_email¶
Alamat surel yang sah. Secara awalan Django menggunakan
DEFAULT_FROM_EMAIL.
- extra_context¶
Kamus data kontek yang akan ditambahkan ke data kontek awalan yang diteruskan ke cetakan.
- html_email_template_name¶
Nama lengkap cetakan yang akan digunakan untuk membuat surel banyak bagian text/html dengan tautan setel ulang sandi. Secara awalan, email HTML tidak dikirim.
- extra_email_context¶
Kamus data kontek yang akan tersedia di cetakan surel. Ini dapat digunakan untuk mengganti nilai konteks cetakan awalan yang tercantum di bawah ini, mis.
domain.
Kontek cetakan
form: Formulir (lihatform_classdiatas) untuk mengatur kembali sandi pengguna.
Konteks cetakan surel:
email: Sebuah nama lain untukuser.emailuser:Usersaat ini, menurut pada bidang formuliremail. Hanya pengguna aktif yang dapa menyetel kembali sandi mereka (User.is_active adalah True).site_name: Sebuah nama lain untuksite.name. Jika anda tidak mempunyai kerangka kerja situs terpasang, ini akan disetel ke nilai darirequest.META['SERVER_NAME']. Untuk lebih di situs, lihat Kerangka kerja "sites".domain: Sebuah nama lain untuksite.domain. Jika anda tidak mempunyai kerangka kerja situs terpasang, ini akan disetel ke nilai darirequest.get_host().protocol: http atau httpsuid: Primary key pengguna disandikan dalam base 64.token: Token untuk memeriksa bahwa tautan menyetel kembali adalah sah.
Contoh
registration/password_reset_email.html(cetakan badan email):Someone asked for password reset for email {{ email }}. Follow the link below: {{ protocol}}://{{ domain }}{% url 'password_reset_confirm' uidb64=uid token=token %}
Konteks cetakan sama digunakan untuk cetakan subyek. Subyek harus berupa strng teks polosbaris tunggal.
- class PasswordResetDoneView[sumber]¶
Nama URL:
password_reset_doneHalaman muncul setelah pengguna telah disurelkan sebuah tautan untuk menyetel kembali sandi mereka. Tampilan ini dipanggil sebagai awalan jika
PasswordResetViewtidak mempunyai kumpulan URLsuccess_urlyang jelas.Catatan
Jika alamat surel disediakan tidak ada di sistem, pengguna adalah tidak aktif, atau mempunyai sebuah sandi tidak berguna, pengguna akan masih dialihkan ke tampilan ini tetapi tidak ada surel yang akan dikirim.
Atribut
- template_name¶
Nama lengkap cetakan yang akan digunakan. Awalan ke
registration/password_reset_done.htmljika tidak disediakan.
- extra_context¶
Kamus data kontek yang akan ditambahkan ke data kontek awalan yang diteruskan ke cetakan.
- class PasswordResetConfirmView[sumber]¶
Nama URL:
password_reset_confirmMengajukan sebuah formulir untuk memasukkan sebuah sandi baru.
Argumen katakunci dari URL:
uidb64: id pengguna disandikan dalam base 64.token: Token untuk memeriksa bahwa sandi adalah sah.
Atribut
- template_name¶
Nama lengkap cetakan untuk menampilkan tampilan konfirmasi kata sandi. Nilai awalannya adalah
registration/password_reset_confirm.html.
- token_generator¶
Contoh kelas untuk memeriksa kata sandi. Ini akan awalan ke
default_token_generator, ini adalah instance daridjango.contrib.auth.tokens.PasswordResetTokenGenerator.
- post_reset_login¶
Boolean yang menunjukkan apakah pengguna harus diautentikasi secara otomatis setelah setel ulang kata sandi berhasil. Awalan ke
False.
- post_reset_login_backend¶
Jalur bertitik ke backend autentikasi untuk digunakan saat mengautentikasi pengguna jika
post_reset_loginadalahTrue. Diperlukan hanya jika anda memiliki beberapa konfigurasiAUTHENTICATION_BACKENDS. Awalan keTidak Ada.
- form_class¶
Form yang akan digunakan untuk mengatur password. Awalan ke
SetPasswordForm.
- success_url¶
URL untuk dialihkan setelah setel ulang kata sandi selesai. Awalan ke
'password_reset_complete'.
- extra_context¶
Kamus data kontek yang akan ditambahkan ke data kontek awalan yang diteruskan ke cetakan.
- reset_url_token¶
Parameter token ditampilkan sebagai komponen URL setel ulang kata sandi. Awalan ke
'set-password'.
Kontek cetakan
form: Formulir (lihatform_classabove) untuk pengaturan san pengguna baru.validlink: Boolean, True jika tautan (perpaduan dariuidb64dantoken) adalah sah atau tidak digunakan.
- class PasswordResetCompleteView[sumber]¶
Nama URL:
password_reset_completeMenghadirkan sebuah tampilan yang menginformasikan pengguna bahwa sandi telah berhasil dirubah.
Atribut
- template_name¶
Nama lengkap cetakan untuk menampilkan tampilan. Awalannya adalah
registration/password_reset_complete.html.
- extra_context¶
Kamus data kontek yang akan ditambahkan ke data kontek awalan yang diteruskan ke cetakan.
Fungsi pembantu¶
- redirect_to_login(next, login_url=None, redirect_field_name='next')[sumber]¶
Dialihkan ke halaman masuk, dan kemudian kembali ke URL lain setelah berhasil masuk.
Argumen diwajibkan:
next: URL untuk mengalihkan setelah berhasil masuk.
Argumen pilihan
login_url: URL dari halaman masuk untuk mengalihkan. Awalan menjadisettings.LOGIN_URLjika tidak diberikan.redirect_field_name: Nama bidangGETmengandung URL untuk pengalihan setelah masukj. Menimpanextjika parameterGETdilewatkan.
Formulir siap pakai¶
Jika anda tidak ingin menggunakan tampilan siap-pakai, tetapi ingin dengan meyakinkan tidak menulis formulir untuk kegunaan ini, sistem autentifikasi menyediakan beberapa formulir siap-pakai ditempatkan di django.contrib.auth.forms:
Catatan
Formulir autentifikasi siap-pakai membuat pendapat tertentu tentang model user yang mereka bekerja dengannya. Jika anda sedang menggunakan sebuah custom user model, itu mungkin diperlukan menentukan formulir anda sendiri untuk sistem autentifikasi. Untuk informasi lebih, mengacu pada dokumentasi tentang using the built-in authentication forms with custom user models.
- class AdminPasswordChangeForm[sumber]¶
A form used in the admin interface to change a user's password, including the ability to set an
unusable password, which blocks the user from logging in with password-based authentication.Mengambil argumen
usersebagai argumen penempatan pertama.
- class AdminUserCreationForm[sumber]¶
A form used in the admin interface to create a new user. Inherits from
UserCreationForm.It includes an additional
usable_passwordfield, enabled by default. Ifusable_passwordis enabled, it verifies thatpassword1andpassword2are non empty and match, validates the password usingvalidate_password(), and sets the user's password usingset_password(). Ifusable_passwordis disabled, no password validation is done, and password-based authentication is disabled for the user by callingset_unusable_password().
- class AuthenticationForm[sumber]¶
Sebuah formulir untuk pengguna masuk.
Mengambil
requestsebagai argumen penempatan pertama, yang disimpan pada instance formulir untuk digunakan oleh sub-kelas.- confirm_login_allowed(user)[sumber]¶
Secara awalan,
AuthenticationFormmenolak pengguna yang benderais_activedisetel menjadiFalse. Anda mungkin menimpa kebiasaan ini dengan kebijakan penyesuaian untuk menentukan pengguna mana dapat masuk. Lakukan ini dengan formulir penyesuaian yang mensubkelasAuthenticationFormdan menimpa metodeconfirm_login_allowed(). Metode ini harus memunculkanValidationErrorjika pengguna yang diberikan tidak masuk.Sebagai contoh, untuk mengizinkan semua pengguna masuk tanpa memperhatikan keadaan "active":
from django.contrib.auth.forms import AuthenticationForm class AuthenticationFormWithInactiveUsersOkay(AuthenticationForm): def confirm_login_allowed(self, user): pass
(Dalam kasus ini, anda akan butuh menggunakan sebuah backend autentifikasi yang megnzinkan pengguna tidak aktif, seperti
AllowAllUsersModelBackend.)Atau mengizinkan hanya beberapa pengguna aktif untuk masuk:
class PickyAuthenticationForm(AuthenticationForm): def confirm_login_allowed(self, user): if not user.is_active: raise ValidationError( _("This account is inactive."), code="inactive", ) if user.username.startswith("b"): raise ValidationError( _("Sorry, accounts starting with 'b' aren't welcome here."), code="no_b_users", )
- class BaseUserCreationForm[sumber]¶
Sebuah
ModelFormuntuk membuat pengguna baru. Ini adalah kelas dasar yang disarankan jika anda perlu menyesuaikan formulir pembuatan pengguna.It has three fields:
username(from the user model),password1, andpassword2. It verifies thatpassword1andpassword2match, validates the password usingvalidate_password(), and sets the user's password usingset_password().
- class PasswordChangeForm[sumber]¶
Sebuah formulir untuk mengizinkan seorang pengguna merubah sandi mereka.
- class PasswordResetForm[sumber]¶
Sebuah formulir untuk membangkitkan dan mensurelkan tautan penggunaan satu-kali untuk menyetel kembali sandi pengguna.
- send_mail(subject_template_name, email_template_name, context, from_email, to_email, html_email_template_name=None)[sumber]¶
Uses the arguments to send an
EmailMultiAlternatives. Can be overridden to customize how the email is sent to the user. If you choose to override this method, be mindful of handling potential exceptions raised due to email sending failures.- Parameter:
subject_template_name -- cetakan untuk subyek.
email_template_name -- cetakan untuk badan surel.
context -- konteks dilewatkan ke
subject_template,email_template, danhtml_email_template(jika itu bukanNone).from_email -- surel pengirim
to_email -- surel dari peminta.
html_email_template_name -- cetakan untuk badan HTML; awalan menjadi
None, dimana kasus sebuah surel teks polos dikirim.
Secara awalan,
save()mengumpulkancontextdengan variabel sama yangPasswordResetViewmelewatkan ke konteks surelnya.
- class SetPasswordForm[sumber]¶
Formulir yang membiarkan pengguma merubah sandi mereka tanpa memasukkan sandi lama.
- class UserChangeForm[sumber]¶
Sebuah formulir digunakan di antarmuka admin untuk merubah infromasi dan perizinan pengguna.
- class UserCreationForm[sumber]¶
Mewarisi dari
BaseUserCreationForm. Untuk membantu mencegah kebingungan dengan nama pengguna yang mirip, formulir tidak mengizinkan nama pengguna yang berbeda hanya untuk berjaga-jaga.
Pembuktian keaslian data di cetakan¶
Pengguna masuk saat ini dan perizinan mereka dibuat tersedia di template context ketika anda menggunakan RequestContext.
Secara teknis
Secara teknis, variabel-variabel ini hanya dibuat tersedia di konteks cetakan jika anda menggunakan pengolah konteks RequestContext dan 'django.contrib.auth.context_processors.auth' adalah diadakan. Itu berada di berkas pengaturan dibangkitkan awalan. Untuk lebih, lihat RequestContext docs.
Pengguna¶
Ketika membangun sebuah cetakan RequestContext, pengguna masuk saat ini, antara instance User atau instance AnonymousUser, disimpan di variabel cetakan {{ user }}:
{% if user.is_authenticated %}
<p>Welcome, {{ user.username }}. Thanks for logging in.</p>
{% else %}
<p>Welcome, new user. Please log in.</p>
{% endif %}
Variabel konteks cetakan ini tidak tersedia jika sebuah RequestContext tidak sedang digunakan.
Hak akses¶
Perizinan pengguna masuk saat ini disimpan di variabel cetakan {{ perms }}. Ini adalah sebuah instance dari django.contrib.auth.context_processors.PermWrapper, yaitu sebuah proxy cetakan-ramah dari perizinan.
Mengevaluasi pencarian atribut tunggal dari {{ perms }} sebagai boolean adalah proksi untuk User.has_module_perms(). Misalnya, untuk memeriksa apakah pengguna yang masuk memiliki izin di aplikasi foo:
{% if perms.foo %}
Mengevaluasi pencarian atribut dua-tingkat sebagai boolean adalah proksi ke User.has_perm(). Misalnya, untuk memeriksa apakah pengguna yang masuk memiliki izin foo.add_vote:
{% if perms.foo.add_vote %}
Ini adalah beberapa contoh lengkap dari perizinan pemeriksaan dalam sebuah cetakan:
{% if perms.foo %}
<p>You have permission to do something in the foo app.</p>
{% if perms.foo.add_vote %}
<p>You can vote!</p>
{% endif %}
{% if perms.foo.add_driving %}
<p>You can drive!</p>
{% endif %}
{% else %}
<p>You don't have permission to do anything in the foo app.</p>
{% endif %}
Itu memungkinkan juga mencari perizinan dengan pernyataan {% if in %}. Sebagai contoh:
{% if 'foo' in perms %}
{% if 'foo.add_vote' in perms %}
<p>In lookup works, too.</p>
{% endif %}
{% endif %}
Mengelola pengguna di admin¶
Ketika anda mempunyai kedua django.contrib.admin dan django.contrib.auth terpasang, admin menyediakan cara yang nyaman untuk menampilkan dan mengelola pengguna, kelompok, dan perizinan. Pengguna dapat dibuat dan dihapus seperti model Django apapun. Kelompok dapat dibuat, dan perizinan dapat diberikan ke pengguna atau kelompok. Sebuah catatan dari pengguna menyunting model dibuat dalam admin juga disimpan dan ditampilkan.
Membuat pengguna¶
You should see a link to "Users" in the "Auth" section of the main admin index page. The "Add user" admin page is different than standard admin pages in that it requires you to choose a username and password before allowing you to edit the rest of the user's fields. Alternatively, on this page, you can choose a username and disable password-based authentication for the user.
Juga catat: jika anda ingin seorang akun pengguna dapat membuat pengguna menggunakan situs admin Django, anda akan butuh memberikan mereka perizinan untuk menambahkan pengguna dan merubah pengguna (yaitu, perizinan "Add user" dan "Change user"). Jika sebuah akun mempunyai perizinan untuk menambah pengguna tetapi tidak merubah mereka, yang akun tidak dapat menambah pengguna. Kenapa, Karena jika anda mempunyai perizinan menambahkan pengguna, anda mempunyai kekuasaan membuat superuser, yang dapat kemudian, di gilirannya, rubah pengguna lain. Sehingga Django membuatuhkan tambah dan merubah perizinan sebagai ukuran keamanan sedikit.
Bijaksanalah tentang bagaimana anda mengizinkan pengguna mengelola perizinan. Jika anda memberikan bukan-superuser kemampuan menyunting pengguna, ini adalah akhirnya sama seperti memberikan mereka keadaan superuser karena mereka akan dapat memperbaiki perizinan dari pengguna menyertakan mereka sendiri!
Merubah sandi¶
User passwords are not displayed in the admin (nor stored in the database), but the password storage details are displayed. Included in the display of this information is a link to a password change form that allows admins to change or unset user passwords.