


Cara berurusan dengan Sesi dan Kuki dalam Python
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', # ... ]
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
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)
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
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
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_age
Parameter 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. samesite
Parameter 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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











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.

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 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 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.

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.

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.

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.

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.
