目錄
什麼是跨站請求偽造(CSRF)攻擊?
如何在Laravel中使用中間件進行CSRF保護?
配置CSRF令牌
使用CSRF中間件
自訂CSRF錯誤處理
總結
首頁 php框架 Laravel 如何在Laravel中使用中間件進行跨站請求偽造(CSRF)保護

如何在Laravel中使用中間件進行跨站請求偽造(CSRF)保護

Nov 02, 2023 am 11:16 AM
laravel 中介軟體 csrf

如何在Laravel中使用中間件進行跨站請求偽造(CSRF)保護

在現代網路應用程式中,跨站請求偽造(CSRF)攻擊已成為一種常見的攻擊方式,Laravel是一款流行的PHP框架,它內建了CSRF保護機制,使用中間件可以非常方便地為應用程式添加CSRF保護。

本文將介紹如何在Laravel中使用中間件進行CSRF保護,並提供具體的程式碼範例。

什麼是跨站請求偽造(CSRF)攻擊?

跨站請求偽造攻擊,英文名為Cross-Site Request Forgery,簡稱CSRF,是一種透過偽造使用者身分發動惡意請求的攻擊方式。

攻擊者通常透過欺騙使用者點擊帶有惡意連結的頁面或在受害者登入的網站中插入惡意腳本的方式來實施CSRF攻擊。當受害者在登入狀態下,攻擊者發起一系列惡意請求(例如修改密碼、發表留言等),這些請求看起來對受害者來說是合法的,但實際上這些請求是由攻擊者發起的,這樣就會對受害者造成一定的危害。

如何在Laravel中使用中間件進行CSRF保護?

Laravel為我們提供了一個非常方便的機制來保護應用程式免受CSRF攻擊。 Laravel框架中內建了CSRF保護機制,可以透過中間件方式來實現。

在Laravel中,我們使用CSRF中間件來檢查POST、PUT、DELETE請求上的CSRF令牌是否有效。預設情況下,Laravel會在應用程式中加入VerifyCsrfToken中間件,並自動檢查這些要求的CSRF令牌是否有效。

如果CSRF令牌無效,Laravel將拋出一個TokenMismatchException異常,並提供一個預設的錯誤視圖。我們也可以根據自己的需求自訂錯誤處理方式。

配置CSRF令牌

Laravel會在每個使用者會話中為應用程式產生一個CSRF令牌,我們可以在應用config/csrf.php的設定文件中調整CSRF令牌的配置。此設定檔可讓您設定CSRF COOKIE和CSRF令牌在請求中的名稱。

<?php

return [

    /*
    |--------------------------------------------------------------------------
    | CSRF Cookie Name
    |--------------------------------------------------------------------------
    |
    | The name of the cookie used to store the CSRF token.
    |
    */

    'cookie' => 'XSRF-TOKEN',

    /*
    |--------------------------------------------------------------------------
    | CSRF Header Name
    |--------------------------------------------------------------------------
    |
    | The name of the CSRF header used to store the CSRF token.
    |
    */

    'header' => 'X-XSRF-TOKEN',

    /*
    |--------------------------------------------------------------------------
    | CSRF Token Expiration
    |--------------------------------------------------------------------------
    |
    | The number of minutes that the CSRF token should be considered valid.
    |
    */

    'expire' => 60,

];
登入後複製

使用CSRF中間件

Laravel中的VerifyCsrfToken中間件將檢查在路由中定義的任何POST、PUT或DELETE請求上的CSRF令牌是否有效。預設情況下,套用的routes/web.php檔案除了web中間件外,還會使用VerifyCsrfToken中間件。

可以在中間件群組中新增CSRF中間件,以便在應用程式中的其他路由中使用。為了使用中間件保護路由,我們可以使用middleware方法將其新增至路由定義中,如下所示:

Route::middleware(['web', 'csrf'])->group(function () {
    //
});
登入後複製

自訂CSRF錯誤處理

預設情況下,如果使用VerifyCsrfToken中間件偵測到CSRF令牌不正確,Laravel將拋出一個TokenMismatchException異常,並提供一個預設的錯誤視圖。

我們可以在app/Exceptions/Handler.php檔案中嘗試擷取CSRF異常並指定我們自己的錯誤處理方式。下面是一個自訂CSRF異常處理程序的範例:

<?php

namespace AppExceptions;

use Exception;
use IlluminateFoundationExceptionsHandler as ExceptionHandler;
use IlluminateSessionTokenMismatchException;

class Handler extends ExceptionHandler
{
    /**
     * A list of the exception types that should be reported.
     *
     * @var array
     */
    protected $dontReport = [
        TokenMismatchException::class,
    ];

    /**
     * Report or log an exception.
     *
     * @param  Exception  $exception
     * @return void
     *
     * @throws Exception
     */
    public function report(Exception $exception)
    {
        parent::report($exception);
    }

    /**
     * Render an exception into an HTTP response.
     *
     * @param  IlluminateHttpRequest  $request
     * @param  Exception  $exception
     * @return IlluminateHttpResponse
     *
     * @throws Exception
     */
    public function render($request, Exception $exception)
    {
        if ($exception instanceof TokenMismatchException) {
            // 处理CSRF异常
            return redirect()
                ->back()
                ->withInput($request->input())
                ->with('error', 'CSRF Token Mismatch');
        }

        return parent::render($request, $exception);
    }

}
登入後複製

在上面的程式碼中,我們捕獲了TokenMismatchException異常,並使用with方法將錯誤訊息儲存到error快閃記憶體資料中。稍後,我們可以在視圖中使用with方法來存取這個閃存資料。

最後,我們可以在檢視中為任何需要提交POST、PUT或DELETE請求的表單新增CSRF令牌欄位。使用csrf_field方法即可在表單中產生CSRF令牌字段,如下所示:

<form method="POST" action="/example">
    {{ csrf_field() }}

    <!-- Your form fields go here... -->

    <button type="submit">Submit</button>
</form>
登入後複製

總結

在本文中,我們介紹如何在Laravel中使用中間件保護應用免受CSRF攻擊。我們透過配置CSRF令牌、使用預設的VerifyCsrfToken中間件以及自訂CSRF錯誤處理方式等措施,有效地提高了應用程式的安全性。相信這些技術可以幫助您建立更安全的網路應用程式。

以上是如何在Laravel中使用中間件進行跨站請求偽造(CSRF)保護的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Laravel和CodeIgniter的最新版本對比 Laravel和CodeIgniter的最新版本對比 Jun 05, 2024 pm 05:29 PM

Laravel9和CodeIgniter4的最新版本提供了更新的功能和改進。 Laravel9採用MVC架構,提供資料庫遷移、驗證及模板引擎等功能。 CodeIgniter4採用HMVC架構,提供路由、ORM和快取。在性能方面,Laravel9的基於服務提供者設計模式和CodeIgniter4的輕量級框架使其具有出色的性能。在實際應用中,Laravel9適用於需要靈活性和強大功能的複雜項目,而CodeIgniter4適用於快速開發和小型應用程式。

PHP 框架安全指南:如何防止 CSRF 攻擊? PHP 框架安全指南:如何防止 CSRF 攻擊? Jun 01, 2024 am 10:36 AM

PHP框架安全指南:如何防止CSRF攻擊?跨站點請求偽造(CSRF)攻擊是一種網路攻擊,其中攻擊者誘騙用戶在受害者的網路應用程式中執行非預期操作。 CSRF如何運作? CSRF攻擊利用了一個事實:大多數Web應用程式允許在同一個網域內不同頁面之間發送請求。攻擊者會建立惡意頁面,該頁面向受害者的應用程式發送請求,觸發未經授權的操作。如何防止CSRF攻擊? 1.使用反CSRF令牌:向每個使用者分配一個唯一的令牌,將其儲存在會話或Cookie中。在應用程式中包含一個隱藏字段,用於提交該令牌

Laravel 和 CodeIgniter 中資料處理能力的比較如何? Laravel 和 CodeIgniter 中資料處理能力的比較如何? Jun 01, 2024 pm 01:34 PM

比較Laravel和CodeIgniter的資料處理能力:ORM:Laravel使用EloquentORM,提供類別物件關係映射,而CodeIgniter使用ActiveRecord,將資料庫模型表示為PHP類別的子類別。查詢建構器:Laravel具有靈活的鍊式查詢API,而CodeIgniter的查詢建構器更簡單,基於陣列。資料驗證:Laravel提供了一個Validator類,支援自訂驗證規則,而CodeIgniter的驗證功能內建較少,需要手動編碼自訂規則。實戰案例:用戶註冊範例展示了Lar

Laravel - Artisan 指令 Laravel - Artisan 指令 Aug 27, 2024 am 10:51 AM

Laravel - Artisan 指令 - Laravel 5.7 提供了處理和測試新指令的新方法。它包括測試 artisan 命令的新功能,下面提到了演示?

Laravel 和 CodeIgniter 對於初學者來說哪一個比較友善? Laravel 和 CodeIgniter 對於初學者來說哪一個比較友善? Jun 05, 2024 pm 07:50 PM

對於初學者來說,CodeIgniter的學習曲線更平緩,功能較少,但涵蓋了基本需求。 Laravel提供了更廣泛的功能集,但學習曲線稍陡。在性能方面,Laravel和CodeIgniter都表現出色。 Laravel有更廣泛的文件和活躍的社群支持,而CodeIgniter更簡單、輕量級,具有強大的安全功能。在建立部落格應用程式的實戰案例中,Laravel的EloquentORM簡化了資料操作,而CodeIgniter需要更多的手動配置。

Laravel和CodeIgniter:哪種框架更適合大型專案? Laravel和CodeIgniter:哪種框架更適合大型專案? Jun 04, 2024 am 09:09 AM

在選擇大型專案框架時,Laravel和CodeIgniter各有優勢。 Laravel針對企業級應用程式而設計,提供模組化設計、相依性注入和強大的功能集。 CodeIgniter是一款輕量級框架,更適合小型到中型項目,強調速度和易用性。對於具有複雜需求和大量用戶的大型項目,Laravel的強大功能和可擴展性更為合適。而對於簡單專案或資源有限的情況下,CodeIgniter的輕量級和快速開發能力則較為理想。

Laravel和CodeIgniter:哪種框架比較適合小型專案? Laravel和CodeIgniter:哪種框架比較適合小型專案? Jun 04, 2024 pm 05:29 PM

對於小型項目,Laravel適用於大型項目,需要強大的功能和安全性。 CodeIgniter適用於非常小的項目,需要輕量級和易用性。

Laravel 和 CodeIgniter 的模板引擎哪一個比較好? Laravel 和 CodeIgniter 的模板引擎哪一個比較好? Jun 03, 2024 am 11:30 AM

比較了Laravel的Blade和CodeIgniter的Twig模板引擎,根據專案需求和個人偏好進行選擇:Blade基於MVC語法,鼓勵良好程式碼組織和模板繼承。 Twig是第三方函式庫,提供靈活語法、強大過濾器、擴充支援和安全沙箱。

See all articles