Django系列教程(13)——Cookie和Session應用場景及案例

目錄

什么是cookie,cookie的應用場景及缺點

Django中如何使用cookie

Cookie使用示例

什么是session及session的工作原理

Django中如何使用會話session

Session使用示例

小結


HTTP協議本身是”無狀態”的,在一次請求和下一次請求之間沒有任何狀態保持,服務器無法識別來自同一用戶的連續請求。有了cookie和session,服務器就可以利用它們記錄客戶端的訪問狀態了,這樣用戶就不用在每次訪問不同頁面都需要登錄了。

什么是cookie,cookie的應用場景及缺點

cookie是一種數據存儲技術, 它是將一段文本保存在客戶端(瀏覽器或本地電腦)的一種技術,并且可以長時間的保存。當用戶首次通過客戶端訪問服務器時,web服務器會發送給客戶端的一小段信息。客戶端瀏覽器會將這段信息以cookie形式保存在本地某個目錄下的文件內。當客戶端下次再發送請求時會自動將cookie也發送到服務器端,這樣服務器端通過查驗cookie內容就知道該客戶端之前訪問過了。

cookie的常見應用場景包括:

  • 判斷用戶是否已經登錄
  • 記錄用戶登錄信息(比如用戶名,上次登錄時間)
  • 記錄用戶搜索關鍵詞

cookie的缺點在于其并不可靠和不安全,主要原因如下:

  • 瀏覽器不一定會保存服務器發來的cookie,用戶可以通過設置選擇是否禁用cookie。
  • cookie是有生命周期的(通過Expire設置),如果超過周期,cookie就會被清除。
  • HTTP數據通過明文發送,容易受到攻擊,因此不能在cookie中存放敏感信息(比如信用卡號,密碼等)。
  • cookie以文件形式存儲在客戶端,用戶可以隨意修改的。

Django中如何使用cookie

第一步:提供響應數據時設置cookie(保存到客戶端)

response.set_cookie(cookie_name, value, max_age = None, expires = None) # key : cookie的名稱
# value : 保存的cookie的值
# max_age: 保存的時間,以秒為單位
# expires: 過期時間,為datetime對象或時間字符串

例子:?response.set_cookie('username','John',600)

注意:Django的視圖默認返回的response是不包含cookie的,需手動調用set_cookie方法。

下面是3個設置cookie的例子:

# 例子1:不使用模板
response = HttpResponse("hello world")
response.set_cookie(key,value,max_age)
return response# 例子2: 使用模板
response = render(request,'xxx.html', context)
response.set_cookie(key,value,max_age)
return response# 例子3: 重定向
response = HttpResponseRedirect('/login/')
response.set_cookie(key,value,max_age)
return response

第二步: 獲取COOKIES中的數據, 進行處理驗證

# 方法一
request.COOKIES['username']# 方法二
request.COOKIES.get('username','')

客戶端再次發送請求時,request會攜帶本地存儲的cookie信息,視圖中你可以通過request.COOKIES獲取。

為了防止獲取不能存在的Key報錯,你可以通過如下方式檢查一個cookie是否已存在。

request.COOKIES.has_key('cookie_name')

如果你希望刪除某個cookie,你可以使用如下方法:

response.delete_cookie('username')

Cookie使用示例

下面是django中使用cookie驗證用戶是否已登錄的一個示例。用戶首次登錄時設置cookie,再次請求時驗證請求攜帶的cookie。

# 如果登錄成功,設置cookie
def login(request):if request.method == 'POST':form = LoginForm(request.POST)if form.is_valid():username = form.cleaned_data['username']password = form.cleaned_data['password']user = User.objects.filter(username__exact=username, password__exact=password)if user:response = HttpResponseRedirect('/index/')# 將username寫入瀏覽器cookie,有效時間為360秒response.set_cookie('username', username, 360)return responseelse:return HttpResponseRedirect('/login/')else:form = LoginForm()return render(request, 'users/login.html', {'form': form})# 通過cookie判斷用戶是否已登錄
def index(request):# 讀取客戶端請求攜帶的cookie,如果不為空,表示為已登錄帳號username = request.COOKIES.get('username', '')if not username:return HttpResponseRedirect('/login/')return render(request, 'index.html', {'username': username})

什么是session及session的工作原理

session又名會話,其功能與應用場景與cookie類似,用來存儲少量的數據或信息。但由于數據存儲在服務器上,而不是客戶端上,所以比cookie更安全。不過當用戶量非常大時,所有的會話信息都存儲于服務器會對服務器造成一定的壓力。

Django中如何使用會話session

第一步:檢查基本設置

Django中使用session首選需要確保settings.py中已開啟了SessionMiddleware中間件。

'django.contrib.sessions.middleware.SessionMiddleware',

Django默認使用數據庫存儲每個session的sessionid, 所以你還需確保INSTALLED_APPS?是包含如下app:

'django.contrib.sessions',

當然你還可以使用更快的文件或緩存來存儲會話信息,可以通過SESSION_ENGINE設置就行。

第二步:使用session

request.session是一個字典,你可以在視圖和模板中直接使用它。

# 設置session的值
request.session['key'] = value
request.session.set_expiry(time): 設置過期時間,0表示瀏覽器關閉則失效# 獲取session的值
request.session.get('key',None)# 刪除session的值, 如果key不存在會報錯
del request.session['key']# 判斷一個key是否在session里
'fav_color' in request.session# 獲取所有session的key和value
request.session.keys()
request.session.values()
request.session.items()

另外,settings.py?還有兩項有關session比較重要的設置: 1、SESSION_COOKIE_AGE:以秒為單位,session的有效時間,可以通過set_expiry?方法覆蓋。 2、SESSION_EXPIRE_AT_BROWSER_CLOSE:默認為Flase,是否設置為瀏覽器關閉,會話自動失效。

Session使用示例

下面是django中使用session進行用戶登錄和登出的一個示例。用戶首次登錄時設置session,退出登錄時刪除session。

# 如果登錄成功,設置session
def login(request):if request.method == 'POST':form = LoginForm(request.POST)if form.is_valid():username = form.cleaned_data['username']password = form.cleaned_data['password']user = User.objects.filter(username__exact=username, password__exact=password)if user:# 將username寫入session,存入服務器request.session['username'] = usernamereturn HttpResponseRedirect('/index/')else:return HttpResponseRedirect('/login/')else:form = LoginForm()return render(request, 'users/login.html', {'form': form})# 通過session判斷用戶是否已登錄
def index(request):# 獲取session中usernameusername = request.session.get('username', '')if not username:return HttpResponseRedirect('/login/')return render(request, 'index.html', {'username': username})# 退出登錄
def logout(request):try:del request.session['username']except KeyError:passreturn HttpResponse("You're logged out.")

下面是通過session控制不讓用戶連續評論兩次的例子。實際應用中我們還可以通過session來控制用戶登錄時間,記錄訪問歷史,記錄購物車信息等等。

from django.http import HttpResponsedef post_comment(request, new_comment):if request.session.get('has_commented', False):return HttpResponse("You've already commented.")c = comments.Comment(comment=new_comment)c.save()request.session['has_commented'] = Truereturn HttpResponse('Thanks for your comment!')

小結

cookie和session都是一種存儲少量數據的技術,用來記錄客戶端的訪問狀態,區別在于一個存儲在客戶端,一個存儲在服務器端。Django中使用cookie和session都非常方便,都是基于先設置再獲取的原則,可以靈活地用于各個場景。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/72794.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/72794.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/72794.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

c++類和對象(下篇)下

下面就來補充一下c雷和對象最后一點內容. 首先先補充一下上一篇博客上c類和對象(下篇)上-CSDN博客最后學習的靜態成員變量的小練習求123...n_牛客題霸_牛客網 (nowcoder.com)下面就是題解.靈活的運用了靜態成員變量不銷毀的特點,建立數組利用構造函數來完成n次相加. class A{ …

《TCP/IP網絡編程》學習筆記 | Chapter 19:Windows 平臺下線程的使用

《TCP/IP網絡編程》學習筆記 | Chapter 19:Windows 平臺下線程的使用 《TCP/IP網絡編程》學習筆記 | Chapter 19:Windows 平臺下線程的使用內核對象內核對象的定義內核對象歸操作系統所有 基于 Windows 的線程創建進程與線程的關系Windows 中線程的創建方…

分布式事務解決方案:Seata原理詳解與實戰教程

一、為什么需要Seata? 在微服務架構中,跨服務的事務管理成為核心痛點: 傳統事務失效:服務拆分導致無法使用本地事務數據不一致風險:網絡抖動、服務宕機等情況導致數據錯亂復雜場景處理難:涉及多個數據庫、…

docker需要sudo才能使用

一種方法是添加當前用戶到docker組里去,當時添加的時候貌似是沒問題的,但是現在又不可以了 產生的報錯 ? docker images Cannot connect to the Docker daemon at unix:///home/ying/.docker/desktop/docker.sock. Is the docker daemon running?解決…

學習記錄 6 pointnet復現

一、復現代碼 然后去找相關的2d的聲吶圖像分類的算法 融合可以搞的,雖然有文獻但是不多,感覺也是可以的 """ Author: Benny Date: Nov 2019 """import os import sys import torch import numpy as npimport datetime …

Linux 文件操作-標準IO函數3- fread讀取、fwrite寫入、 fprintf向文件寫入格式化數據、fscanf逐行讀取格式化數據的驗證

目錄 1. fread 從文件中讀取數據 1.1 讀取次數 每次讀取字節數 < 原內容字節數 1.2 讀取次數 每次讀取字節數 > 原內容字節數 2.fwrite 向文件中寫入數據 2.1寫入字符串驗證 2.2寫入結構體驗證 3. fprintf 將數據寫入到指定文件 4. fscanf 從文件中逐行讀取內容…

Python 中下劃線 “_” 的多面性:從變量到約定

# Python中下劃線“_”的多面性&#xff1a;從變量到約定 在Python的語法體系里&#xff0c;下劃線“_”看似毫不起眼&#xff0c;實則扮演著極為重要且多樣化的角色。它不僅能作為普通變量參與編程&#xff0c;更在多個特殊場景下有著獨特的用途與約定。深入理解下劃線的各種…

深入 Linux 聲卡驅動開發:核心問題與實戰解析

1. 字符設備驅動如何為聲卡提供操作接口&#xff1f; 問題背景 在 Linux 系統中&#xff0c;聲卡被抽象為字符設備。如何通過代碼讓應用程序能夠訪問聲卡的錄音和播放功能&#xff1f; 核心答案 1.1 字符設備驅動的核心結構 Linux 字符設備驅動通過 file_operations 結構體定…

基于Spring Boot的圖書管理系統的設計與實現(LW+源碼+講解)

專注于大學生項目實戰開發,講解,畢業答疑輔導&#xff0c;歡迎高校老師/同行前輩交流合作?。 技術范圍&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬蟲、數據可視化、安卓app、大數據、物聯網、機器學習等設計與開發。 主要內容&#xff1a;…

記錄 macOS 上使用 Homebrew 安裝的軟件

Homebrew 是 macOS 上最受歡迎的軟件包管理器之一&#xff0c;能夠輕松安裝各種命令行工具和 GUI 應用。本文記錄了我通過 Homebrew 安裝的各種軟件&#xff0c;并對它們的用途和基本使用方法進行介紹。 &#x1f37a; Homebrew 介紹 Homebrew 是一個開源的包管理器&#xff…

個人AI助手的未來:Yi AI開源系統助力快速搭建

摘要 Yi AI推出了一站式個人AI助手平臺解決方案&#xff0c;助力用戶快速搭建專屬AI助手。該平臺采用全套開源系統&#xff0c;涵蓋前端應用、后臺管理及小程序功能&#xff0c;并基于MIT協議開放使用。同時&#xff0c;平臺集成了本地RAG方案&#xff0c;利用Milvus與Weaviate…

dpkg-architecture命令詳解

dpkg-architecture 是 Debian 系系統中用于處理軟件包架構相關操作的工具&#xff0c;尤其在軟件包構建和交叉編譯環境中至關重要。以下是其核心功能及用法的詳細說明&#xff1a; ?一、核心功能? ?架構查詢與驗證? 顯示或驗證當前系統&#xff08;DEB_HOST_ARCH&#xff…

STM32HAL庫,解決串口UART中斷接收到的第一個字節數據丟失

1.問題描述&#xff1a; 只有上電后第一次接收到的第一字節數據會丟失&#xff0c;往后再接收也不會存在問題了。 2.先貼出來重寫UART中斷回調函數 我在接收到第一字節數據后開啟定時器中斷的&#xff0c;做一個超時處理&#xff0c;每次接收到數據會對定時器計數值清零&…

解決 vxe-table 固定列對不齊,滾動后錯位、展開行遮擋的問題,解決渲染空白、邊框丟失問題

解決 vxe-table 固定列對不齊&#xff0c;滾動后錯位、展開行遮擋的問題&#xff0c;解決渲染空白、邊框丟失問題。 解決方法&#xff0c;更新到最新版本就完美解決了&#xff1b;v4 版本更新到 v4.12&#xff0c;v3版本更新到 v3.14 查看官網&#xff1a;https://vxetable.cn…

React相關面試題

以下是150道React面試題及其詳細回答&#xff0c;涵蓋了React的基礎知識、組件、狀態管理、路由、性能優化等多個方面&#xff0c;每道題目都盡量詳細且簡單易懂&#xff1a; React基礎概念類 1. 什么是React&#xff1f; React是一個用于構建用戶界面的JavaScript庫&#xff…

設備健康管理系統是什么,設備健康管理系統多少錢?

想象一下&#xff0c;你的汽車在儀表盤報警前 3 天&#xff0c;手機就收到 “發動機軸承剩余壽命 1500 公里” 的提醒 —— 這就是 ** 設備健康管理系統&#xff08;EHM&#xff09;** 的日常。在制造業&#xff0c;設備故障每年造成全球 3.4 萬億美元損失&#xff0c;而 80% 的…

Redis項目:秒殺業務

/*** 搶購秒殺券** param voucherId* return*/TransactionalOverridepublic Result seckillVoucher(Long voucherId) {// 1、查詢秒殺券SeckillVoucher voucher seckillVoucherService.getById(voucherId);// 2、判斷秒殺券是否合法if (voucher.getBeginTime().isAfter(LocalD…

區塊鏈(Blockchain)

區塊鏈&#xff08;Blockchain&#xff09;是一種去中心化、分布式的賬本技術&#xff0c;它通過密碼學保證數據的安全性和不可篡改性。它的核心特點包括去中心化、不可篡改性、可追溯性、智能合約等。 區塊鏈的關鍵概念 區塊&#xff08;Block&#xff09;&#xff1a;每個區…

和鯨科技受邀赴中國氣象局氣象干部培訓學院湖南分院開展 DeepSeek 趨勢下的人工智能技術應用專題培訓

為深入貫徹落實國家關于人工智能與氣象業務深度融合的戰略部署&#xff0c;提升在實際業務中應用人工智能技術解決問題的能力&#xff0c;推動氣象現代化高質量發展&#xff0c;中國氣象局氣象干部培訓學院湖南分院于 2025 年 3 月 14 日組織開展 “DeepSeek 等人工智能技術在氣…

Ubuntu 24 常用命令方法

文章目錄 環境說明1、賬號管理1.1、啟用 root 2、包管理工具 apt & dpkg2.1、apt 簡介 & 阿里源配置2.2、dpkg 簡介2.3、apt 和 dpkg 兩者之間的關系2.4、常用命令 3、啟用 ssh 服務4、防火墻5、開啟遠程登錄6、關閉交換分區7、build-essential&#xff08;編譯和開發軟…