搜尋
首頁php框架Laravel如何在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
laravel单点登录方法详解laravel单点登录方法详解Jun 15, 2022 am 11:45 AM

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于单点登录的相关问题,单点登录是指在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统,下面一起来看一下,希望对大家有帮助。

一起来聊聊Laravel的生命周期一起来聊聊Laravel的生命周期Apr 25, 2022 pm 12:04 PM

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于Laravel的生命周期相关问题,Laravel 的生命周期从public\index.php开始,从public\index.php结束,希望对大家有帮助。

laravel中guard是什么laravel中guard是什么Jun 02, 2022 pm 05:54 PM

在laravel中,guard是一个用于用户认证的插件;guard的作用就是处理认证判断每一个请求,从数据库中读取数据和用户输入的对比,调用是否登录过或者允许通过的,并且Guard能非常灵活的构建一套自己的认证体系。

laravel中asset()方法怎么用laravel中asset()方法怎么用Jun 02, 2022 pm 04:55 PM

laravel中asset()方法的用法:1、用于引入静态文件,语法为“src="{{asset(‘需要引入的文件路径’)}}"”;2、用于给当前请求的scheme前端资源生成一个url,语法为“$url = asset('前端资源')”。

实例详解laravel使用中间件记录用户请求日志实例详解laravel使用中间件记录用户请求日志Apr 26, 2022 am 11:53 AM

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于使用中间件记录用户请求日志的相关问题,包括了创建中间件、注册中间件、记录用户访问等等内容,下面一起来看一下,希望对大家有帮助。

laravel中间件基础详解laravel中间件基础详解May 18, 2022 am 11:46 AM

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于中间件的相关问题,包括了什么是中间件、自定义中间件等等,中间件为过滤进入应用的 HTTP 请求提供了一套便利的机制,下面一起来看一下,希望对大家有帮助。

laravel路由文件在哪个目录里laravel路由文件在哪个目录里Apr 28, 2022 pm 01:07 PM

laravel路由文件在“routes”目录里。Laravel中所有的路由文件定义在routes目录下,它里面的内容会自动被框架加载;该目录下默认有四个路由文件用于给不同的入口使用:web.php、api.php、console.php等。

laravel中的scope怎么用laravel中的scope怎么用Jun 09, 2022 am 11:15 AM

在laravel中,scope用于处理模型中的数据,在模型中可以定义scope开头方法,这类方法可以通过模型直接调用,被称为查询作用域,语法为“public function scope首字母大写单词($query){...}”。

See all articles

熱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.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SublimeText3 Mac版

SublimeText3 Mac版

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

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具