”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 是什么导致 Laravel 中 POST 和 PUT 方法出现 419 状态代码?

是什么导致 Laravel 中 POST 和 PUT 方法出现 419 状态代码?

发布于2024-11-06
浏览:548

What Causes the 419 Status Code in Laravel for POST and PUT Methods?

了解 Laravel API 中 POST 和 PUT 方法的 419 状态码

使用 Laravel 开发 RESTful API 时,经常会遇到 419 POST 和 PUT 方法的状态代码。此错误是由于 Laravel 的 CSRF 令牌验证过程所致。

在 Laravel 5.4 及更早版本中,所有请求都启用了 CSRF 令牌,包括 POST 和 PUT 方法。这是为了保护应用程序免受跨站点请求伪造 (CSRF) 攻击。默认情况下,CSRF 令牌作为表单中的隐藏字段添加到视图中。

提交 POST 或 PUT 请求时,Laravel 期望收到有效的 CSRF 令牌以及请求数据。如果未找到有效令牌,Laravel 会生成“419 CSRF 令牌不匹配”异常并返回 419 状态代码响应。

从 CSRF 保护中排除路由

To要解决此问题,您可以从 CSRF 令牌验证中排除某些路由。在 Laravel 5.5 及以上版本中,您可以使用 api.php 文件代替 web.php 进行 API 路由,并且默认情况下不启用 CSRF 验证。

如果您使用 web.php 进行 API 路由,则可以通过将它们的 URI 添加到VerifyCsrfToken 中间件的 $ except 属性来将它们排除在 CSRF 令牌验证之外。例如:

namespace App\Http\Middleware;

use Illuminate\Foundation\Http\Middleware\VerifyCsrfToken as BaseVerifier;

class VerifyCsrfToken extends BaseVerifier
{
    protected $except = [
        '/api/*',
    ];
}

这将从 CSRF 令牌验证中排除以 /api 开头的所有路由。

非 API 路由的替代解决方案

如果排除来自CSRF 保护不合适,您可以对路由组内的特定方法禁用 CSRF 验证。例如:

Route::group(['middleware' => 'web'], function () {
    Route::post('/my-route', 'MyController@store')->withoutMiddleware('verify-csrf-token');
});

这将禁用对 /my-route 的 POST 请求的 CSRF 令牌验证。

版本声明 本文转载于:1729254976如有侵犯,请联系[email protected]删除
最新教程 更多>

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3