Rumah >pembangunan bahagian belakang >Tutorial Python >Kemahiran pengurusan kebenaran dalam rangka kerja Django
Dengan populariti aplikasi web, semakin banyak perniagaan memerlukan pengurusan kebenaran. Sebagai rangka kerja pembangunan web yang popular, Django menyediakan set mekanisme pengurusan kebenaran yang agak lengkap. Dalam artikel ini, kami akan membincangkan teknik pengurusan kebenaran dalam rangka kerja Django.
Pengurusan kebenaran rangka kerja Django terutamanya merangkumi aspek berikut:
Pengesahan Pengguna
Django menyediakan modul Django.contrib.auth untuk pengesahan pengguna. Modul ini termasuk pendaftaran pengguna, log masuk, log keluar dan fungsi lain Kami hanya perlu membuat konfigurasi yang berkaitan mengikut keperluan dalam dokumen untuk menggunakannya. Kaedah pengesahan yang lebih biasa digunakan ialah dua berikut:
Dalam kaedah pengesahan ini, selepas pengguna log masuk buat kali pertama, pelayan akan Maklumat disimpan dalam Sesi Setiap kali anda mengakses halaman yang memerlukan pengesahan kebenaran, pelayan akan menyemak sama ada maklumat pengguna wujud dalam Sesi. Jika ia tidak wujud, ia akan mengubah hala ke halaman log masuk. Kaedah ini sesuai untuk sistem kecil, tetapi akan meningkatkan beban pada pelayan dalam sistem besar.
Dalam kaedah pengesahan ini, pelayan akan menjana rentetan Token dan mengembalikannya kepada pelanggan, dan pelanggan perlu Membawa Token ke atas . Pelayan mengesahkan identiti pengguna dengan mengesahkan Token. Pendekatan ini dipanggil pengesahan "tanpa negara" kerana ia tidak memerlukan keadaan untuk dikekalkan pada bahagian pelayan.
Keizinan Pengguna
Dalam Django, kebenaran pengguna merujuk terutamanya kepada kebenaran pengguna untuk mengakses sumber yang sepadan. Django menyediakan dua kaedah kebenaran:
Dalam kaedah kebenaran ini, kami memberikan kebenaran yang sepadan kepada peranan pengguna yang berbeza, dan pengguna log masuk Kemudian mereka akan mendapat kebenaran yang sepadan mengikut peranan mereka. Sebagai contoh, kami boleh memberikan kebenaran yang lebih tinggi kepada pentadbir untuk membenarkan mereka mengubah suai latar belakang.
Dalam kaedah kebenaran ini, kami memberikan kebenaran yang sepadan kepada setiap sumber (atau setiap URL), dan pengguna mengakses Apabila mengakses sumber, anda perlu mengesahkan sama ada mereka mempunyai kebenaran yang sepadan. Kaedah ini lebih terperinci, tetapi memerlukan pemberian kebenaran yang sepadan kepada setiap sumber, yang memerlukan beban kerja yang lebih besar.
Pengesahan kebenaran
Django menyediakan kaedah penghias untuk pengesahan kebenaran, yang boleh kami tambahkan pada fungsi paparan yang memerlukan pengesahan. Penghias yang disediakan dalam rangka kerja Django adalah seperti berikut:
Apabila mengakses halaman yang memerlukan log masuk, jika pengguna tidak log masuk, ubah hala ke lalai halaman log masuk.
digunakan untuk melindungi fungsi paparan tertentu dan hanya pengguna yang mempunyai kebenaran yang sepadan boleh mengaksesnya.
Anda boleh menyesuaikan fungsi pengesahan kebenaran mengikut keperluan anda sendiri Fungsi paparan hanya boleh diakses apabila fungsi mengembalikan True.
Tiga penghias di atas boleh disesuaikan dan dilanjutkan mengikut keperluan anda sendiri.
Ringkasan
Rangka kerja Django menyediakan mekanisme pengurusan kebenaran yang lengkap. Penggunaan mekanisme ini dengan betul boleh menambah keselamatan dan fleksibiliti pada aplikasi web dengan mudah. Adalah disyorkan bahawa semasa mereka bentuk aplikasi web, cuba ikuti "prinsip keistimewaan paling rendah", iaitu, hanya membenarkan pengguna mengakses sumber yang mereka perlukan untuk mengurangkan berlakunya kelemahan keselamatan.
Atas ialah kandungan terperinci Kemahiran pengurusan kebenaran dalam rangka kerja Django. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!