溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Django CSRF跨站請求偽造防護過程解析

發(fā)布時間:2020-10-22 04:22:47 來源:腳本之家 閱讀:160 作者:Tanglaoer 欄目:開發(fā)技術

前言

CSRF全稱Cross-site request forgery(跨站請求偽造),是一種網絡的攻擊方式,也被稱為“One Click Attack”或者Session Riding,通常縮寫為CSRF或者XSRF。

攻擊原理

1、用戶訪問正常的網站A,瀏覽器就會保存網站A的cookies。

2、用戶在訪問惡意網站B, 網站B上有某個隱藏的鏈接會自動請求網站A的鏈接地址,例如表單提交,傳指定的參數(shù)。

3、惡意網站B的自動化請求,執(zhí)行就是在用戶A的同一個瀏覽器上,因此在訪問網站A的時候,瀏覽器會自動帶上網站A的cookies。

4、所以網站A在接收到請求之后,可判斷當前用戶登錄狀態(tài),所以根據(jù)用戶的權限做具體的操作邏輯。

防范措施

1、在指定表單或者請求頭的里面添加一個隨機值做為參數(shù)。

2、在響應的cookie里面也設置該隨機值。

3、用戶正常提交表單的時候會默認帶上表單中的隨機值,瀏覽器會自動帶上cookie里面的隨機值,那么服務器下次接受到請求之后就可以取出兩個值進行校驗。

4、對于網站B來說網站B在提交表單的時候不知道該隨機值是什么,所以就形成不了攻擊。

Django中CSRF中間件

django在創(chuàng)建項目的時候,默認就會有添加中間進行CSRF的保護,在MIDDLEWARE可以看到加載了 django.middleware.csrf.CsrfViewMiddleware 的中間件,這里是全局設置,也可以局部設置。

全局保護:直接啟用中間件就可以了。

局部保護: from django.views.decorators.csrf import csrf_exempt,csrf_protect ,使用裝飾器進行驗證。

csrf_protect :為當前函數(shù)強制設置防跨站請求偽造功能,即便settings中沒有設置全局中間件;

csrf_exempt :取消當前函數(shù)防跨站請求偽造功能,即便settings中設置了全局中間件。

驗證

在POST請求提交數(shù)據(jù)的時候,django會去檢查是否有一個csrf的隨機字符串,如果沒有就會返回403沒有權限訪問。

表單驗證

在form表單里面需要添加{%csrf_token%},Django會自動渲染隱藏的input輸入框:

<input type="hidden" name="csrfmiddlewaretoken" value="2Sb0DQwDVgOQ8i3n1BaG1MUPLEYr6ZGaCLYa14maOQM0Ami5ddQOR6hfXuD2mrmA">

在表單提交的時候,中間件會驗證csrfmiddlewaretoken。

通過ajax提交

通過cookies獲取到csrftoken,

function getCookie(name) {
  var r = document.cookie.match("\\b" + name + "=([^;]*)\\b");
  return r ? r[1] : undefined;
}
$.ajax({
  url:"/api/v1.0/orders",
  type:"POST",
  data: JSON.stringify(data),
  contentType: "application/json",
  dataType: "json",
  headers:{
    "X-CSRFtoken":getCookie("csrf_token"),
  },

局部禁用或者啟用

1、如果是函數(shù)視圖,可以直接在函數(shù)加上裝飾器即可:

from django.views.decorators.csrf import csrf_exempt,csrf_protect
@csrf_exempt
def login(request):
  if request.method == 'GET':
    return render(request,'login.html')
  else:
    return HttpResponse('ok')

2、如果是類視圖,需要使用方法裝飾器進行封裝

from django.utils.decorators import method_decorator
from django.views.decorators.csrf import csrf_exempt,csrf_protect
from django.views.generic import TemplateView

@method_decorator(csrf_exempt)
class LoginView(TemplateView):
  template_name = 'login.html'
  def post():
    return HttpResponse('ok')

3、直接裝飾as_view()方式,在URLconf里面設置。

from django.views.decorators.csrf import csrf_exempt,csrf_protect
urlpatterns = [
  path('login/', csrf_exempt(LoginView.as_view()),name="login"),
]

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

AI