Jadual Kandungan
Sesi dan Kuki
Penggunaan Sesi
Aktifkan SessionMiddleware
Konfigurasi sesi
Menggunakan Sesi
Penggunaan Kuki
Baca Kuki
Tulis Kuki
Pemilihan Sesi dan Kuki
Rumah pembangunan bahagian belakang Tutorial Python Cara berurusan dengan Sesi dan Kuki dalam Python

Cara berurusan dengan Sesi dan Kuki dalam Python

May 10, 2023 am 11:19 AM
python cookie session

Sesi dan Kuki

Dalam pembangunan web, Sesi dan Kuki ialah dua teknologi biasa yang digunakan untuk memindahkan data antara klien dan pelayan. Sesi ialah teknologi bahagian pelayan yang menyimpan data pengguna di bahagian pelayan, manakala Cookie ialah teknologi sisi klien yang menyimpan data pengguna dalam penyemak imbas.

Penggunaan Sesi

Sesi ialah teknologi yang menjimatkan data pengguna di bahagian pelayan. Dalam Django, Session dilaksanakan melalui SessionMiddleware middleware ini akan membaca data Sesi pengguna daripada storan sebelum setiap permintaan diproses dan menyimpannya dalam atribut request.session, supaya fungsi paparan Anda boleh mengakses data Sesi.

Aktifkan SessionMiddleware

Untuk menggunakan Sesi, anda perlu mengaktifkan SessionMiddleware dalam fail konfigurasi projek Django, supaya Django akan membuat objek Sesi secara automatik untuk setiap permintaan. Tambahkan MIDDLEWARE pada django.contrib.sessions.middleware.SessionMiddleware untuk mengaktifkan SessionMiddleware.

MIDDLEWARE = [
    # ...
    'django.contrib.sessions.middleware.SessionMiddleware',
    # ...
]
Salin selepas log masuk

Konfigurasi sesi

Django’s Session mempunyai pelbagai kaedah storan, termasuk pangkalan data, cache, sistem fail, dsb. Dalam fail konfigurasi Django, anda boleh menggunakan SESSION_ENGINE untuk menentukan kaedah storan Sesi dan gunakan SESSION_COOKIE_AGE untuk menentukan masa tamat tempoh Sesi.

SESSION_ENGINE = 'django.contrib.sessions.backends.cache'
SESSION_CACHE_ALIAS = 'default'
SESSION_COOKIE_AGE = 86400
Salin selepas log masuk

Konfigurasi di atas menunjukkan bahawa Sesi disimpan dalam cache Menggunakan cache lalai, masa tamat tempoh Sesi ialah 1 hari.

Menggunakan Sesi

Menggunakan Sesi dalam fungsi paparan adalah sangat mudah, anda hanya perlu mengakses atribut request.session. Berikut ialah contoh penggunaan Sesi:

def index(request):
    count = request.session.get('count', 0)
    request.session['count'] = count + 1
    return HttpResponse('count: %d' % count)
Salin selepas log masuk

Dalam contoh di atas, kami mengakses atribut request.session dan menggunakan kaedah get untuk mendapatkan data Sesi bernama count. Jika tiada count data dalam Sesi, kaedah get akan mengembalikan nilai lalai 0. Kami kemudian menambah 1 pada count dan menyimpannya pada Sesi. Apabila pengguna mengakses fungsi paparan sekali lagi, kita boleh mendapatkan data count yang disimpan sebelum ini, kemudian menambah 1 padanya dan mengemas kininya pada Sesi.

Perlu diambil perhatian bahawa data yang disimpan dalam Sesi mempunyai had saiz. Dalam fail konfigurasi Django, anda boleh menentukan had saiz Sesi melalui SESSION_COOKIE_MAX_SIZE. Jika data yang disimpan dalam Sesi melebihi had, pengecualian SuspiciousOperation akan dilemparkan.

Penggunaan Kuki

Kuki ialah teknologi yang menyimpan data pengguna di sisi pelanggan. Dalam Django, anda boleh menggunakan objek HttpRequest dan HttpResponse untuk membaca dan menulis kuki.

Baca Kuki

Dalam objek HttpRequest, semua kuki boleh diakses melalui atribut COOKIES. Berikut ialah contoh membaca kuki:

def index(request):
    count = request.COOKIES.get('count', 0)
    response = HttpResponse('count: %d' % count)
    response.set_cookie('count', count + 1)
    return response
Salin selepas log masuk

Dalam contoh di atas, kami mengakses atribut request.COOKIES dan menggunakan kaedah get untuk mendapatkan kuki bernama count. Jika tiada count data dalam kuki, kaedah get akan mengembalikan nilai lalai 0. Kami kemudian menambah 1 pada count dan menyimpannya pada kuki. Akhir sekali, kami mengembalikan objek HttpResponse dan menggunakan kaedah set_cookie untuk menyimpan count yang dikemas kini pada kuki.

Perlu diambil perhatian bahawa data yang disimpan dalam kuki juga terhad dalam saiz. Had saiz kuki mungkin berbeza dalam pelayar yang berbeza. Dalam Django, anda boleh menentukan had saiz kuki melalui SESSION_COOKIE_MAX_SIZE. Jika data yang disimpan dalam kuki melebihi had, pengecualian SuspiciousOperation akan dilemparkan.

Tulis Kuki

Dalam objek HttpResponse, anda boleh menggunakan kaedah set_cookie untuk menulis Kuki. Berikut ialah contoh menulis kepada kuki:

def index(request):
    response = HttpResponse('Hello, world!')
    response.set_cookie('name', 'value', max_age=3600, expires=None, path='/', domain=None, secure=False, httponly=False, samesite=None)
    return response
Salin selepas log masuk

Dalam contoh di atas, kami mencipta objek HttpResponse dan menggunakan kaedah set_cookie untuk menukar objek bernama name dengan nilai value Kuki ditulis pada jawapan. max_ageParameter menentukan jangka hayat maksimum kuki, dalam beberapa saat. Parameter expires menentukan masa tamat tempoh kuki Jika tidak dinyatakan, ini bermakna kuki tamat tempoh apabila penyemak imbas ditutup. Parameter path menentukan laluan tindakan kuki, iaitu, hanya permintaan di bawah laluan yang ditentukan akan membawa kuki. Parameter domain menentukan skop kuki, iaitu, hanya permintaan untuk mengakses nama domain yang ditentukan akan membawa kuki. Parameter secure menentukan sama ada kuki hanya boleh dihantar melalui protokol HTTPS. Parameter httponly menentukan sama ada kuki hanya boleh diakses melalui protokol HTTP dan bukan melalui JavaScript. samesiteParameter menentukan atribut SameSite bagi kuki, yang menentukan sama ada kuki hanya boleh digunakan dalam tapak yang sama.

Pemilihan Sesi dan Kuki

Apabila menggunakan Sesi dan Kuki, anda harus memilih teknologi yang sesuai berdasarkan senario aplikasi tertentu. Secara umumnya, jika anda perlu menyimpan sejumlah besar data atau perlu memastikan keselamatan data, anda harus menggunakan teknologi Sesi jika anda perlu menyimpan sejumlah kecil data atau perlu berkongsi data antara pelanggan, anda harus menggunakan teknologi Kuki;

Selain itu, perlu diingatkan bahawa kedua-dua Sesi dan Kuki mempunyai risiko keselamatan. Jika Sesi atau Kuki dipintas oleh penyerang berniat jahat, data pengguna akan dibocorkan. Oleh itu, apabila menggunakan Sesi dan Kuki, langkah keselamatan yang sesuai hendaklah dipilih berdasarkan senario aplikasi tertentu, seperti menggunakan protokol HTTPS untuk menghantar data, menetapkan atribut HttpOnly bagi Kuki, dsb.

Atas ialah kandungan terperinci Cara berurusan dengan Sesi dan Kuki dalam Python. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1660
14
Tutorial PHP
1261
29
Tutorial C#
1234
24
PHP dan Python: Paradigma yang berbeza dijelaskan PHP dan Python: Paradigma yang berbeza dijelaskan Apr 18, 2025 am 12:26 AM

PHP terutamanya pengaturcaraan prosedur, tetapi juga menyokong pengaturcaraan berorientasikan objek (OOP); Python menyokong pelbagai paradigma, termasuk pengaturcaraan OOP, fungsional dan prosedur. PHP sesuai untuk pembangunan web, dan Python sesuai untuk pelbagai aplikasi seperti analisis data dan pembelajaran mesin.

Memilih antara php dan python: panduan Memilih antara php dan python: panduan Apr 18, 2025 am 12:24 AM

PHP sesuai untuk pembangunan web dan prototaip pesat, dan Python sesuai untuk sains data dan pembelajaran mesin. 1.Php digunakan untuk pembangunan web dinamik, dengan sintaks mudah dan sesuai untuk pembangunan pesat. 2. Python mempunyai sintaks ringkas, sesuai untuk pelbagai bidang, dan mempunyai ekosistem perpustakaan yang kuat.

PHP dan Python: menyelam mendalam ke dalam sejarah mereka PHP dan Python: menyelam mendalam ke dalam sejarah mereka Apr 18, 2025 am 12:25 AM

PHP berasal pada tahun 1994 dan dibangunkan oleh Rasmuslerdorf. Ia pada asalnya digunakan untuk mengesan pelawat laman web dan secara beransur-ansur berkembang menjadi bahasa skrip sisi pelayan dan digunakan secara meluas dalam pembangunan web. Python telah dibangunkan oleh Guidovan Rossum pada akhir 1980 -an dan pertama kali dikeluarkan pada tahun 1991. Ia menekankan kebolehbacaan dan kesederhanaan kod, dan sesuai untuk pengkomputeran saintifik, analisis data dan bidang lain.

Python vs JavaScript: Keluk Pembelajaran dan Kemudahan Penggunaan Python vs JavaScript: Keluk Pembelajaran dan Kemudahan Penggunaan Apr 16, 2025 am 12:12 AM

Python lebih sesuai untuk pemula, dengan lengkung pembelajaran yang lancar dan sintaks ringkas; JavaScript sesuai untuk pembangunan front-end, dengan lengkung pembelajaran yang curam dan sintaks yang fleksibel. 1. Sintaks Python adalah intuitif dan sesuai untuk sains data dan pembangunan back-end. 2. JavaScript adalah fleksibel dan digunakan secara meluas dalam pengaturcaraan depan dan pelayan.

Cara menjalankan Python Kod Sublime Cara menjalankan Python Kod Sublime Apr 16, 2025 am 08:48 AM

Untuk menjalankan kod python dalam teks luhur, anda perlu memasang plug-in python terlebih dahulu, kemudian buat fail .py dan tulis kod itu, dan akhirnya tekan Ctrl B untuk menjalankan kod, dan output akan dipaparkan dalam konsol.

Di mana untuk menulis kod di vscode Di mana untuk menulis kod di vscode Apr 15, 2025 pm 09:54 PM

Kod penulisan dalam Kod Visual Studio (VSCode) adalah mudah dan mudah digunakan. Hanya pasang VSCode, buat projek, pilih bahasa, buat fail, tulis kod, simpan dan jalankannya. Kelebihan vscode termasuk sumber lintas platform, bebas dan terbuka, ciri-ciri yang kuat, sambungan yang kaya, dan ringan dan cepat.

Bolehkah kod studio visual digunakan dalam python Bolehkah kod studio visual digunakan dalam python Apr 15, 2025 pm 08:18 PM

Kod VS boleh digunakan untuk menulis Python dan menyediakan banyak ciri yang menjadikannya alat yang ideal untuk membangunkan aplikasi python. Ia membolehkan pengguna untuk: memasang sambungan python untuk mendapatkan fungsi seperti penyempurnaan kod, penonjolan sintaks, dan debugging. Gunakan debugger untuk mengesan kod langkah demi langkah, cari dan selesaikan kesilapan. Mengintegrasikan Git untuk Kawalan Versi. Gunakan alat pemformatan kod untuk mengekalkan konsistensi kod. Gunakan alat linting untuk melihat masalah yang berpotensi lebih awal.

Cara menjalankan python dengan notepad Cara menjalankan python dengan notepad Apr 16, 2025 pm 07:33 PM

Running Python Code di Notepad memerlukan Python Executable dan NPPExec plug-in untuk dipasang. Selepas memasang Python dan menambahkan laluannya, konfigurasikan perintah "python" dan parameter "{current_directory} {file_name}" dalam plug-in nppexec untuk menjalankan kod python melalui kunci pintasan "f6" dalam notepad.

See all articles