国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
生成和存儲(chǔ)抗CSRF代幣
在表單提交中驗(yàn)證令牌
不要忘記AJAX請(qǐng)求和API
獎(jiǎng)勵(lì)提示:Samesite Cookie和僅HTTP形式
首頁(yè) 后端開(kāi)發(fā) php教程 如何防止PHP中的跨站點(diǎn)偽造偽造(CSRF)攻擊?

如何防止PHP中的跨站點(diǎn)偽造偽造(CSRF)攻擊?

Jun 28, 2025 am 02:25 AM
php csrf

為了防止PHP中的CSRF攻擊,請(qǐng)實(shí)施抗CSRF令牌。 1)使用Random_bytes()或BIN2HEX(Random_bytes(32))生成和存儲(chǔ)安全令牌,將它們保存在$ _Session中,并將它們包含在隱藏輸入中。 2)通過(guò)嚴(yán)格比較郵政令牌與會(huì)話存儲(chǔ)的郵政令牌來(lái)驗(yàn)證令牌;以403的錯(cuò)誤拒絕不匹配的請(qǐng)求。 3)通過(guò)將令牌包含在標(biāo)題或車身上,通常從元標(biāo)記中檢索到Ajax/API請(qǐng)求。 4)在輸出令牌時(shí)使用HTMLSpeceialChars()防止XSS泄漏。 5)在登錄等關(guān)鍵操作之后再生代幣。 6)設(shè)置samesite = cookie cookie的嚴(yán)格/lax,并避免進(jìn)行狀態(tài)更改。 7)重新認(rèn)證用戶以進(jìn)行敏感操作。這些步驟確保在所有請(qǐng)求類型中進(jìn)行全面的CSRF保護(hù),同時(shí)保持安全性完整性。

如何防止PHP中的跨站點(diǎn)偽造偽造(CSRF)攻擊?

為了防止PHP中的CSRF攻擊,您需要通過(guò)使用令牌來(lái)實(shí)現(xiàn)堅(jiān)實(shí)的抗CSRF策略。這個(gè)想法很簡(jiǎn)單:每個(gè)改變狀態(tài)的請(qǐng)求(例如表單提交)都應(yīng)包括只有合法用戶知道的獨(dú)特,不可預(yù)測(cè)的令牌。沒(méi)有這個(gè)令牌,服務(wù)器不應(yīng)處理請(qǐng)求。

這是在實(shí)踐中實(shí)際做得很好的方法。


生成和存儲(chǔ)抗CSRF代幣

每當(dāng)您顯示執(zhí)行操作的表格(例如提交設(shè)置或進(jìn)行購(gòu)買)時(shí),生成安全的令牌并將其存儲(chǔ)在服務(wù)器端的某個(gè)地方(例如在會(huì)話中)。

  • 使用random_bytes()bin2hex(random_bytes(32))創(chuàng)建一個(gè)強(qiáng)令牌。
  • 將其保存在$_SESSION中,因此您可以在提交表單時(shí)以后進(jìn)行比較。

例如:

 if(占($ _ session ['csrf_token'])){
    $ _session ['csrf_token'] = bin2hex(Random_bytes(50));
}

然后以您的形式:

 <input type =“隱藏” name =“ csrf_token” value =“ <?= htmlspecialchars($ _ session [&#39;csrf_token&#39;])?>>“)?

這樣,每種表單提交都包含攻擊者無(wú)法猜測(cè)或復(fù)制的令牌。


在表單提交中驗(yàn)證令牌

提交表單時(shí),請(qǐng)檢查帖子數(shù)據(jù)中的令牌是否與會(huì)話中存儲(chǔ)的內(nèi)容匹配。

  • 始終檢查令牌的存在。
  • 比較嚴(yán)格( === ),以避免類型的問(wèn)題。
  • 如果不匹配,請(qǐng)拒絕403錯(cuò)誤或類似的請(qǐng)求。

示例代碼:

 if(!isset($ _ post [&#39;csrf_token&#39;])|| $ _post [&#39;csrf_token&#39;]!== $ _session [&#39;csrf_token&#39;]){
    http_response_code(403);
    DIE(“無(wú)效的CSRF令牌?!保?
}

一個(gè)小但重要的細(xì)節(jié):將令牌輸出到HTML中時(shí),請(qǐng)務(wù)必使用htmlspecialchars()以防止XSS泄漏令牌。

另外,不要忘記在關(guān)鍵操作(例如登錄或密碼更改)之后旋轉(zhuǎn)或再生令牌。


不要忘記AJAX請(qǐng)求和API

如果您的網(wǎng)站使用JavaScript提交表格或撥打API呼叫,則這些請(qǐng)求也需要CSRF保護(hù)。

  • 將CSRF令牌包括在AJAX請(qǐng)求的標(biāo)題或主體中。
  • 您可以將令牌存儲(chǔ)在元標(biāo)簽或內(nèi)聯(lián)腳本中,并在撥打電話時(shí)從那里讀取它。

例如,在您的HTML頭上設(shè)置元標(biāo)記:

 <meta name =“ csrf-token” content =“ <?= htmlspecialchars($ _ session [&#39;csrf_token&#39;])?>>“>”>

然后在您的JS中:

 fetch(&#39;/update-profile&#39;,{
    方法:“帖子”,
    標(biāo)題:{
        &#39;x-csrf-token&#39;:document.queryselector(&#39;meta [name =“ csrf-token”]]&#39;)。內(nèi)容
    },,
    正文:新的UrlsearchParams({名稱:&#39;John Doe&#39;})
});

在后端,在X-CSRF-Token標(biāo)頭中查找令牌,并像常規(guī)表格一樣對(duì)其進(jìn)行驗(yàn)證。

要注意的一件事:如果您要構(gòu)建與您的PHP后端交談的單頁(yè)應(yīng)用程序(SPA)或移動(dòng)應(yīng)用程序,請(qǐng)考慮使用相同的cookie和CSRF代幣一起更好地保護(hù)。


獎(jiǎng)勵(lì)提示:Samesite Cookie和僅HTTP形式

即使有令牌,您也可以采取額外的步驟:

  • 將Samesite設(shè)置為cookie上的SameSite=StrictLax ,以減少交叉原始請(qǐng)求。
  • 確保您的表格僅在需要的情況下接受發(fā)布請(qǐng)求,而不允許獲得基于基于的狀態(tài)更改。
  • 對(duì)于敏感操作(例如刪除帳戶),重新認(rèn)證有助于增加另一層。

這些不是CSRF代幣的替代品,但它們與它們并駕齊驅(qū)。


基本上就是這樣。 PHP中的CSRF保護(hù)歸結(jié)為生成好代幣,正確驗(yàn)證它們,并確保它們包括在所有相關(guān)請(qǐng)求中。它并不是太復(fù)雜了,但是如果您跳過(guò)一步,很容易弄亂。

以上是如何防止PHP中的跨站點(diǎn)偽造偽造(CSRF)攻擊?的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請(qǐng)聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

如何將兩個(gè)PHP陣列組合獨(dú)特的值? 如何將兩個(gè)PHP陣列組合獨(dú)特的值? Jul 02, 2025 pm 05:18 PM

要合并兩個(gè)PHP數(shù)組并保留唯一值,有兩種主要方法。1.對(duì)于索引數(shù)組或僅需值去重的情況,使用array_merge和array_unique組合:先用array_merge($array1,$array2)合并數(shù)組,再用array_unique()去重,最終得到包含所有唯一值的新數(shù)組;2.對(duì)于關(guān)聯(lián)數(shù)組且希望保留第一個(gè)數(shù)組中的鍵值對(duì)時(shí),使用 運(yùn)算符:$result=$array1 $array2,這將確保第一個(gè)數(shù)組中的鍵不會(huì)被第二個(gè)數(shù)組覆蓋。這兩種方法分別適用于不同場(chǎng)景,根據(jù)是否需要保留鍵名或只關(guān)注

如何使用PHP退出功能? 如何使用PHP退出功能? Jul 03, 2025 am 02:15 AM

exit()是PHP中用于立即終止腳本執(zhí)行的函數(shù),常見(jiàn)用途包括:1.在檢測(cè)到異常情況時(shí)提前終止腳本,如文件不存在或驗(yàn)證失??;2.調(diào)試時(shí)輸出中間結(jié)果并停止執(zhí)行;3.結(jié)合header()重定向后調(diào)用exit()防止后續(xù)代碼執(zhí)行;此外,exit()可接受字符串參數(shù)作為輸出內(nèi)容或整數(shù)作為狀態(tài)碼,其別名為die()。

將語(yǔ)義結(jié)構(gòu)應(yīng)用于html的文章,部分和旁邊 將語(yǔ)義結(jié)構(gòu)應(yīng)用于html的文章,部分和旁邊 Jul 05, 2025 am 02:03 AM

在HTML中合理使用語(yǔ)義化標(biāo)簽?zāi)芴嵘?yè)面結(jié)構(gòu)清晰度、可訪問(wèn)性和SEO效果。1.用于獨(dú)立內(nèi)容區(qū)塊,如博客文章或評(píng)論,需保持自包含性;2.用于歸類相關(guān)內(nèi)容,通常包含標(biāo)題,適用于頁(yè)面不同模塊;3.用于與主內(nèi)容相關(guān)但非核心的輔助信息,如側(cè)邊欄推薦或作者簡(jiǎn)介。實(shí)際開(kāi)發(fā)中應(yīng)結(jié)合、等標(biāo)簽,避免過(guò)度嵌套,保持結(jié)構(gòu)簡(jiǎn)潔,并通過(guò)開(kāi)發(fā)者工具驗(yàn)證結(jié)構(gòu)合理性。

如何在PHP中創(chuàng)建數(shù)組? 如何在PHP中創(chuàng)建數(shù)組? Jul 02, 2025 pm 05:01 PM

在PHP中創(chuàng)建數(shù)組的方法有兩種:使用array()函數(shù)或使用中括號(hào)[]。1.使用array()函數(shù)是傳統(tǒng)方式,兼容性好,定義索引數(shù)組如$fruits=array("apple","banana","orange"),關(guān)聯(lián)數(shù)組如$user=array("name"=>"John","age"=>25);2.使用[]是從PHP5.4開(kāi)始支持的更簡(jiǎn)潔的方式,如$color

請(qǐng)求的操作需要高程窗戶 請(qǐng)求的操作需要高程窗戶 Jul 04, 2025 am 02:58 AM

遇到“此操作需要提升權(quán)限”提示時(shí),說(shuō)明你需要管理員權(quán)限才能繼續(xù)。解決方法包括:1.右鍵選擇“以管理員身份運(yùn)行”程序或設(shè)置快捷方式始終以管理員身份運(yùn)行;2.檢查當(dāng)前賬戶是否為管理員賬戶,若不是則切換或請(qǐng)求管理員協(xié)助;3.用管理員權(quán)限打開(kāi)命令提示符或PowerShell執(zhí)行相關(guān)命令;4.在必要時(shí)通過(guò)獲取文件所有權(quán)或修改注冊(cè)表等手段繞過(guò)限制,但此類操作需謹(jǐn)慎并充分了解風(fēng)險(xiǎn)。確認(rèn)權(quán)限身份并嘗試上述方法通??山鉀Q問(wèn)題。

PHP原始帖子數(shù)據(jù)PHP PHP原始帖子數(shù)據(jù)PHP Jul 02, 2025 pm 04:51 PM

在PHP中處理原始POST數(shù)據(jù)的方法是使用$rawData=file_get_contents('php://input'),適用于接收J(rèn)SON、XML或其他自定義格式數(shù)據(jù)。1.php://input是一個(gè)只讀流,僅在POST請(qǐng)求中有效;2.常見(jiàn)問(wèn)題包括服務(wù)器配置或中間件已讀取輸入流導(dǎo)致無(wú)法獲取數(shù)據(jù);3.應(yīng)用場(chǎng)景包括接收前端fetch請(qǐng)求、第三方服務(wù)回調(diào)和構(gòu)建RESTfulAPI;4.與$_POST的區(qū)別在于$_POST自動(dòng)解析標(biāo)準(zhǔn)表單數(shù)據(jù),而原始數(shù)據(jù)適合非標(biāo)準(zhǔn)格式并允許手動(dòng)解析;5.普通HTM

如何在PHP中牢固地處理文件上傳? 如何在PHP中牢固地處理文件上傳? Jul 08, 2025 am 02:37 AM

要安全處理PHP文件上傳需驗(yàn)證來(lái)源與類型、控制文件名與路徑、設(shè)置服務(wù)器限制并二次處理媒體文件。1.驗(yàn)證上傳來(lái)源通過(guò)token防止CSRF并通過(guò)finfo_file檢測(cè)真實(shí)MIME類型使用白名單控制;2.重命名文件為隨機(jī)字符串并根據(jù)檢測(cè)類型決定擴(kuò)展名存儲(chǔ)至非Web目錄;3.PHP配置限制上傳大小及臨時(shí)目錄Nginx/Apache禁止訪問(wèn)上傳目錄;4.GD庫(kù)重新保存圖片清除潛在惡意數(shù)據(jù)。

您如何按值與PHP中的參考傳遞變量? 您如何按值與PHP中的參考傳遞變量? Jul 08, 2025 am 02:42 AM

InPHP,variablesarepassedbyvaluebydefault,meaningfunctionsorassignmentsreceiveacopyofthedata,whilepassingbyreferenceallowsmodificationstoaffecttheoriginalvariable.1.Whenpassingbyvalue,changestothecopydonotimpacttheoriginal,asshownwhenassigning$b=$aorp

See all articles