Django的CSRF保護機制


一、Django的CSRF保護機制

1. 核心原理
  • 作用:防止跨站請求偽造(CSRF)攻擊,確保表單提交來源可信。
  • 實現方式
    • 在模板中使用{% csrf_token %}生成一個隱藏的<input>字段(如csrfmiddlewaretoken)和一個Cookiecsrftoken)。
    • 提交表單時,Django會同時驗證表單字段和Cookie中的token是否匹配。
  • 中間件依賴:由django.middleware.csrf.CsrfViewMiddleware實現,需在MIDDLEWARE配置中啟用。
2. 關鍵流程
# 模板中嵌入CSRF Token
<form method="post">{% csrf_token %}  <!-- 生成隱藏字段 -->...
</form>
  • 生成階段:首次訪問頁面時,中間件生成token并注入響應(Cookie + 表單字段)。
  • 驗證階段:提交表單時,中間件對比POST數據中的token和Cookie中的token,不一致則返回403錯誤。
3. 特殊場景處理
  • AJAX請求:需手動從Cookie讀取token并添加到請求頭(X-CSRFToken)。
  • 豁免CSRF保護:用@csrf_exempt裝飾器標記視圖(謹慎使用)。

二、redirect時附帶locals()與不附帶的區別

1. redirect函數的作用
  • 返回HTTP重定向響應(狀態碼302),不直接渲染模板,而是跳轉到新URL。
  • 語法:redirect('view_name')redirect('/url/')
2. 錯誤用法:redirect(locals())
def my_view(request):user = request.usererror = "Invalid input"return redirect('success_page', locals())  # 錯誤!
  • 問題分析
    • locals()返回當前作用域的所有變量(如user, error),但redirect不接受模板上下文參數
    • 實際效果:重定向時完全忽略locals()中的變量,僅執行URL跳轉。
    • 若需傳遞數據,必須通過URL參數(?key=value)或Session實現。
3. 正確用法:render(request, template, locals())
def my_view(request):user = request.usererror = "Invalid input"return render(request, 'template.html', locals())
  • redirect的區別
    場景redirect(locals())render(request, template, locals())
    HTTP響應類型302重定向200 OK(直接渲染模板)
    數據傳遞方式無效(數據丟失)有效(變量注入模板)
    URL變化瀏覽器地址欄更新為目標URL地址欄不變
    典型用例提交表單后跳轉到結果頁渲染包含表單的頁面
4. 重定向時傳遞數據的正確方法
  • URL參數redirect('success_page?error=Invalid+input')
  • Session
    request.session['error'] = "Invalid input"
    return redirect('success_page')
    

三、最佳實踐總結

  1. CSRF安全
    • 所有POST表單必須包含{% csrf_token %}
    • 避免全局禁用CSRF中間件,優先使用@csrf_exempt局部豁免。
  2. 重定向使用規范
    • 禁止redirect中使用locals(),因其無法傳遞上下文。
    • 需傳遞數據時,改用Session或URL參數。
  3. 模板渲染優化
    • 避免濫用render(..., locals()),顯式傳遞變量更安全(如render(..., {'user': user}),防止意外暴露敏感變量。

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

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

相關文章

JavaScript中的回調函數詳解

JavaScript中的回調函數詳解 1.1 概念 1.1.1 什么是回調函數 **回調函數&#xff08;Callback Function&#xff09;**是你將一個函數的引用&#xff08;指針&#xff09;作為參數傳遞給另一個函數&#xff0c;在那個函數完成任務后調用回來執行你傳遞的函數。簡單的來說就是…

Utils系列之內存池(Fixed size)

內存池核心介紹 廢話不多說&#xff0c;show you code. 我實現了兩套內存池&#xff0c;一個是固定大小的內存池&#xff0c;一個是多重不同大小的內存池。 Fixed size memory pool 設計思路&#xff1a; 我們一個個看&#xff0c;首先我們定義了一個chunk, chunk 里面包含…

ubuntu安裝docker遇到權限問題

問題現象&#xff1a; 使用snap安裝的docker&#xff0c;執行docker build命令構建景象時報錯&#xff1a; [] Building 0.1s (1/1) FINISHED docker:default > [internal] load build definition from Dockerfile 0.0s > > transferring dockerfile: 2B 0.0s ERROR:…

在Linux系統中部署Java項目

1.在Linux中啟動mysql的服務: systemctl start mysql可以采用以下代碼查看狀態: systemctl status mysql如下圖展示綠色代表啟動成功 2.之后進入mysql mysql -uroot -p輸入自己的密碼&#xff0c;這里的密碼不會顯示,直接輸入即可 3.在DG中連接Linux的數據庫 4.修改配置文件…

C++洛谷P1002 過河卒

題目 鏈接&#xff1a;https://www.luogu.com.cn/problem/P1002 解析 這道題適用于了解動態規劃的同學。 變量初始化 初始化B點坐標&#xff08;n, m&#xff09;和馬的坐標&#xff08;a, b&#xff09; 初始化方向數組和動態規劃數組 long long dp[30][30]; int dx[8] …

BlogX項目Go-gin--根據IP獲取地理位置

先定義一個函數來判斷IP地址是否為內網&#xff0c;歸為工具類 // utils/ip/enter.go package ipimport "net"func HasLocalIPAddr(ip string) bool {return HasLocalIP(net.ParseIP(ip)) }// HasLocalIP 檢測 IP 地址是否是內網地址 // 通過直接對比ip段范圍效率更…

鴻蒙系統(HarmonyOS)應用開發之實現瀑布流圖片展示效果

項目概述 科技圖庫是一款基于鴻蒙系統&#xff08;HarmonyOS&#xff09;開發的高品質圖片瀏覽應用&#xff0c;專注于展示精選科技主題圖片。應用采用現代化的瀑布流布局&#xff0c;為用戶提供流暢、直觀的瀏覽體驗&#xff0c;讓科技之美盡收眼底。 主要功能 1. 瀑布流布…

【fish-speech】新模型openaudio-s1-mini嘗鮮

一、配置 顯卡&#xff1a;v100&#xff08;測試簡短語句&#xff0c;顯存實際占用不足6G&#xff09; 二、安裝測試 1. 安裝 1.1 下載源碼 git clone https://github.com/fishaudio/fish-speech.git1.2 安裝系統組件 apt install portaudio19-dev libsox-dev ffmpeg1.3 …

介紹Windows下的由Sysinternals開發的一些小工具

Sysinternals是一個開發了很多Windows下系統工具的公司&#xff0c;這些工具能極大地提高對Windows系統的深入認知。就像它的名字Sys(tem)internals&#xff0c;深入系統里面。這些工具都放在微軟的網站上可以下載到。https://learn.microsoft.com/en-us/sysinternals/ 下載網…

云服務器環境下Linux系統epoll機制與高并發服務器優化實踐

在當今云計算時代&#xff0c;云已成為企業部署高并發服務的首選平臺。本文將深入探討Linux系統核心的epoll機制如何賦能云環境下的高并發服務器&#xff0c;解析其底層工作原理與性能優勢&#xff0c;并對比傳統IO復用模型的差異&#xff0c;幫助開發者構建更高效的云端服務架…

Java爬蟲實戰指南:按關鍵字搜索京東商品

在電商領域&#xff0c;快速獲取商品信息對于市場分析、選品上架、庫存管理和價格策略制定等方面至關重要。京東作為國內領先的電商平臺之一&#xff0c;提供了豐富的商品數據。雖然京東開放平臺提供了官方API來獲取商品信息&#xff0c;但有時使用爬蟲技術來抓取數據也是一種有…

aspose.word在IIS后端DLL中高并發運行,線程安全隔離

aspose.word在IIS后端DLL中運行,加載很慢,如何為全部用戶加載,再每個用戶訪問時在各自線程中直接可以打開WORD文件處理 Aspose.Words 在 IIS 中優化加載性能方案 針對 Aspose.Words 在 IIS 后端 DLL 中加載緩慢的問題&#xff0c;我們可以通過單例模式預加載組件并結合線程安…

鏈表題解——回文鏈表【LeetCode】

一、算法邏輯&#xff08;通順講解每一步思路&#xff09; 我們從 isPalindrome 這個主函數入手&#xff1a; 步驟 1&#xff1a;找到鏈表的中間節點 middleNode 使用 快慢指針法&#xff08;slow 和 fast&#xff09; 快指針一次走兩步&#xff0c;慢指針一次走一步。 當快…

allegro 銅皮的直角邊怎么快速變成多邊形?

像這種&#xff1a; 變成這種&#xff1a; 解決方案&#xff1a; shape edit boundary 點擊鋪銅邊緣就能裁剪

從廚房到代碼臺:用做菜思維理解iOS開發 - Swift入門篇②

從廚房到代碼臺&#xff1a;用做菜思維理解iOS開發 - Swift入門篇② 本章重點? 理解App開發的整體流程熟悉Xcode主界面結構與常用分區跟著步驟動手創建第一個App項目&#xff0c;認識模擬器掌握"打掃廚房"高頻快捷鍵&#xff0c;解決常見疑難雜癥 1、目標 像一個專…

EloqCloud for KV 初體驗:兼容redis的云原生KV數據庫

最近在做一些AI應用的時候&#xff0c;我在想嘗試利用redis的能力緩存一些信息&#xff0c;這使我想去找一個免費的redis來進行使用&#xff0c;在調研的過程中我發現了一款產品EloqCloud for KV可以提供類似的能力&#xff0c;于是嘗試使用了一下&#xff0c;本文記錄了這次體…

企業級路由器技術全解析:從基礎原理到實戰開發

簡介 在當今數字化時代,路由器作為網絡的核心設備,其技術深度與應用廣度直接影響著企業網絡的性能與安全性。本文將全面解析路由器的基礎原理、工作機制以及企業級開發技術,從網絡層尋址到路由協議算法,從安全配置到QoS實現,再到多廠商API開發實戰,旨在幫助網絡工程師和…

day041-web集群架構搭建

文章目錄 0. 老男孩思想-高薪四板斧1. web集群架構圖2. 搭建異地備份服務2.1 服務端-阿里云服務器2.1.1 查看rsync軟件包2.1.2 添加rsync配置文件2.1.3 添加虛擬用戶2.1.4 創建校驗用戶密碼文件2.1.5 創建備份目錄2.1.6 啟動服務2.1.7 開放安全組端口2.1.8 發送檢查郵件 2.2 客…

day44-Django RestFramework(drf)下

1.5 Django RestFramework(下) drf 內置了很多便捷的功能,在接下來的課程中會給大家依次講解下面的內容: 快速上手請求的封裝版本管理認證權限限流序列化視圖條件搜索分頁路由解析器10. 分頁 在查看數據列表的API中,如果 數據量 比較大,肯定不能把所有的數據都展示給用…

機器學習基礎 線性回歸與 Softmax 回歸

機器學習基礎 線性回歸與 Softmax 回歸 文章目錄 機器學習基礎 線性回歸與 Softmax 回歸1. 最小二乘法1.1 數據集定義1.2 最小二乘的矩陣推導1.3 最小二乘的幾何解釋1.4 概率視角下的最小二乘估計 2. 正則化2.1 L1 范數與 L2 范數2.2 正則化的作用2.3 Lasso 回歸的求解2.3.1 L-…