csrf 功能 及 csrf裝飾器使用

来源:https://www.cnblogs.com/guokaifeng/archive/2019/07/01/11111791.html
-Advertisement-
Play Games

csrf 功能 及 csrf裝飾器使用 [TOC] 簡單瞭解csrf 防範措施 瞭解更多csrf點擊 django 中 csrf 配置文件 form表單使用 csrf裝飾器 csrf_exempt使用實例 不需要效驗 csrf_protect 需要效驗 ensure_csrf_cookie 確保生成 ...


目錄

csrf 功能 及 csrf裝飾器使用

簡單瞭解csrf

CSRF(Cross-site request forgery)跨站請求偽造,也被稱為“One Click Attack”或者Session Riding,
通常縮寫為CSRF或者XSRF,是一種對網站的惡意利用。儘管聽起來像跨站腳本(XSS),但它與XSS非常不同,
XSS利用站點內的信任用戶,而CSRF則通過偽裝成受信任用戶的請求來利用受信任的網站。與XSS攻擊相比,
CSRF攻擊往往不大流行(因此對其進行防範的資源也相當稀少)和難以防範,所以被認為比XSS更具危險性。

防範措施 瞭解更多csrf點擊

對於web站點,將持久化的授權方法(例如cookie或者HTTP授權)切換為瞬時的授權方法(在每個form中提供隱藏field),
這將幫助網站防止這些攻擊。一種類似的方式是在form中包含秘密信息、用戶指定的代號作為cookie之外的驗證。
另一個可選的方法是“雙提交”cookie。此方法只工作於Ajax請求,但它能夠作為無需改變大量form的全局修正方法。
如果某個授權的cookie在form post之前正被JavaScript代碼讀取,那麼限制跨域規則將被應用。
如果伺服器需要在Post請求體或者URL中包含授權cookie的請求,那麼這個請求必須來自於受信任的域,
因為其它域是不能從信任域讀取cookie的。
與通常的信任想法相反,使用Post代替Get方法並不能提供卓有成效的保護。因為JavaScript能使用偽造的POST請求。
儘管如此,那些導致對安全產生“副作用”的請求應該總使用Post方式發送。Post方式不會在web伺服器和代理伺服器日誌中留下數據尾巴,
然而Get方式卻會留下數據尾巴。
儘管CSRF是web應用的基本問題,而不是用戶的問題,但用戶能夠在缺乏安全設計的網站上保護他們的帳戶:
通過在瀏覽其它站點前登出站點或者在瀏覽器會話結束後清理瀏覽器的cookie。

django 中 csrf

  • 配置文件

  • form表單使用

csrf裝飾器

from django.views.decorators.csrf import csrf_exempt,csrf_protect,ensure_csrf_cookie#導入方法
csrf_exempt         #某個視圖函數不需要進行csrf校驗
csrf_protect        #某個視圖函數需要進行csrf校驗
ensure_csrf_cookie  #確保生成csrf的cookie
  • csrf_exempt使用實例 不需要效驗

#setting中CSRF中間件未註釋
#使用方法一
from django.views import View
from django.shortcuts import render, redirect, HttpResponse
from django.views.decorators.csrf import csrf_exempt,csrf_protect,ensure_csrf_cookie

class Login(View):
    @method_decorator(csrf_exempt) #csrf_exempt只能載入dispatch上才有效果,所有的方法都不需要驗證
    def dispatch(self, request, *args, **kwargs):
        ret = super().dispatch(request, *args, **kwargs)
        return ret
    def get(self, request, *args, **kwargs):
        pass
    def post(self, request, *args, **kwargs):
        pass
  
#使用方法二
from django.views import View
from django.shortcuts import render, redirect, HttpResponse
from django.views.decorators.csrf import csrf_exempt,csrf_protect,ensure_csrf_cookie

@method_decorator(csrf_exempt,name="dispatch")
class Login(View):
    def get(self, request, *args, **kwargs):
        pass
    def post(self, request, *args, **kwargs):
        pass    
#使用方法三
把csrf_exempt裝飾器直接加在URL路由映射中,使某個視圖函數不經過CSRF驗證
from users import views  
from django.views.decorators.csrf import csrf_exempt  

urlpatterns = [  
    url(r'^admin/', admin.site.urls),  
    url(r'^index/',csrf_exempt(views.index)),  
]

#FBV使用直接加就行
@csrf_exempt  
def index(request):  
    pass
  • 使用實例
#setting中CSRF中間件已註釋
from django.views import View
from django.shortcuts import render, redirect, HttpResponse
from django.views.decorators.csrf import csrf_exempt,csrf_protect,ensure_csrf_cookie

class Login(View):
    @@method_decorator(ensure_csrf_cookie)
    def get(self, request, *args, **kwargs):
        pass
    @method_decorator(csrf_protect)#post需要效驗
    def post(self, request, *args, **kwargs):
        pass
    
#FBV使用直接加就行
@csrf_protect  
def index(request):  
    pass

csrf功能(執行流程)

  • csrf中間件中執行process_request
    • 1 從cookie中獲取到csrftoken的值
    • 2 csrftoken的值放入到 request.META
  • 執行process_view

    • 1 查詢視圖函數是否使用csrf_exempt裝飾器,使用了就不進行csrf的校驗

    • 2 判斷請求方式:

      • 1 如果是GET', 'HEAD', 'OPTIONS', 'TRACE' 不進行csrf校驗

      • 2 其他的請求方式(post,put)

        • 進行csrf校驗:

        • 獲取cookie中csrftoken的值

        • 獲取csrfmiddlewaretoken的值

          • 能獲取到 ——》 request_csrf_token
          • 獲取不到 ——》 獲取請求頭中X-csrftoken的值 ——》request_csrf_token

          • 比較上述request_csrf_token和cookie中csrftoken的值,比較成功接收請求,比較不成功拒絕請求。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 目錄如下 1. 軟體架構的進化 2. 微服務的優勢和不足 3. 微服務架構所帶來的問題及解決方案 1.軟體架構的進化 於筆者經歷來看 架構大致從 單體架構 》MVC 》 微服務 單體架構 單體架構特點在於所有功能業務打包在一個發佈包里,部署在一個web容器中,運行在一個進程里。單體架構的優點在於 容 ...
  • 裝飾器模式主要對現有的類對象進行包裹和封裝,以期望在不改變類對象及其類定義的情況下,為對象添加額外功能。是一種對象結構型模式。需要註意的是,該過程是通過調用被包裹之後的對象完成功能添加的,而不是直接修改現有對象的行為,相當於增加了中間層。類似於python中的@裝飾器。 下麵還是按照老規矩,先來瞭解 ...
  • Spring Cloud是一個基於Spring Boot實現的雲應用開發工具,它為基於JVM的雲應用開發中涉及的配置管理、服務發現、斷路器、智能路由、微代理、控制匯流排、全局鎖、決策競選、分散式會話和集群狀態管理等操作提供了一種簡單的開發框架。 ...
  • 一,Map集合的特點: * * 1.Map集合和Collection集合,沒有關係 * * 2.Map集合的元素是成對存在(夫妻關係) * Collection集合的元素是獨立存在的(單身關係) * * 3.Map集合的元素不能重覆(是元素的key值不能重覆) * * 總結: * Collectio ...
  • # 非函數式: data_list = [] for i in range(1,901): data_list.append('豆谷雲-%s' % i) while True: # 1.你要查看的頁碼 page = int(input("請輸入你要查看的頁碼:")) # 2.每頁顯示多少條數據 pe... ...
  • [TOC] MySQL 之SQL優化詳解(三) 1. 索引優化 一旦建立索引,select 查詢語句的where條件要儘量符合最佳左首碼的原則,如若能做到全值匹配最好。 索引優化的第一個前提就是建好索引,第二個就是避免索引失效   索引失效的場景 1. 如果索引了多列,要遵守最左首碼法則。 ...
  • 首先講一下我為什麼要寫這一系列的文章,現在網上大量的springcloud相關的文章,使用的springboot和springcloud的版本都相對比較老,很多還是在使用springboot1.x的版本,如果嘗鮮想使用springboot2.x的版本,很多配置都和之前的不一樣,有了大量的修改,很多剛 ...
  • 自我介紹 第一次寫博客,先簡單自我介紹一下.我是一名程式員,2年多工作經驗,之前在成都工作,現在在重慶一家車聯網公司.技術一般,但保持有熱情,喜歡折騰新的技術,因為我覺得技術能改善我們的生活,提高工作效率.歡迎大家多多交流. 開發環境推薦 好了,開始今天的主題. 今天主要想給大家講的是我們的日常開發 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...