溫馨提示×

溫馨提示×

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

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

前端知識 |前端安全之CSRF

發(fā)布時間:2020-06-30 09:40:42 來源:網(wǎng)絡(luò) 閱讀:523 作者:海說軟件 欄目:web開發(fā)

CSRF/XSRF(Cross-Site Request Forgery),即跨站請求偽造,也被稱為“One Click Attack”或者Session Riding?;驹硎峭ㄟ^偽裝來自受信任用戶的請求來利用受信任的網(wǎng)站。
前端知識 |前端安全之CSRF
×××原理:
如圖所示,用戶首先訪問網(wǎng)站A,通過登錄身份驗證成功,網(wǎng)站A下發(fā)cookie保存在用戶的瀏覽器中。用戶又去訪問了網(wǎng)站B,網(wǎng)站B在下發(fā)用戶頁面的時候會有一個引誘點擊,這個引誘點擊一般是一個鏈接,這個鏈接一般指向網(wǎng)站A的一個存在漏洞的API接口,尤其這個API接口是GET類型。當(dāng)用戶禁不住誘惑點擊了這個引誘點擊,這個點擊就訪問到了A網(wǎng)站,此時瀏覽器就會自動上傳cookie,此時網(wǎng)站A對cookie進行確認,發(fā)現(xiàn)是合法用戶,此時就會執(zhí)行這個API的動作(以前微博就出現(xiàn)過CSRF×××,出問題的接口導(dǎo)致很多情況多了很多關(guān)注)。

總結(jié)
CSRF能造成×××的原理:
用戶登錄過網(wǎng)站A。
網(wǎng)站A中某一個接口存在著這種漏洞。這兩條件缺一不可。

防御措施

1.Token驗證
×××原理中訪問漏洞接口的時候瀏覽器只上傳了cookie,沒有手動的上傳一個token。這個token是用戶登錄注冊甚至只是訪問網(wǎng)站A,服務(wù)器會自動向用戶本地存儲一個token,在用戶訪問各個接口的時候,如果沒帶這個token,服務(wù)器就不會通過驗證。所以當(dāng)用戶點擊引誘鏈接,這個鏈接只會自動攜帶cookie,但是不會自動攜帶token,這樣就能避免×××。

2.Referer驗證
Referer,即頁面來源。服務(wù)器通過判斷頁面來源是不是自己站點的頁面來源,如果是就執(zhí)行接口動作,如果不是一律攔截。這樣也能避免×××。

3.隱藏令牌
類似于Token驗證,原理是把token放在HTTP頭的自定義屬性中,而不是把信息放在鏈接上,增加了隱蔽性。本質(zhì)上和Token驗證沒什么區(qū)別,只是用法上的一些區(qū)別。

向AI問一下細節(jié)

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

AI